/*
 * CSS especÃ­fico de los block patterns custom del theme.
 *
 * Encolado en frontend (no admin) desde CR_Setup::enqueue_patterns_css.
 * Toma tokens de theme.json vÃ­a custom properties --wp--preset--*.
 */

/* ---------- Variables locales por scope ---------- */

.cr-badge-card,
.cr-grid-hero,
.cr-grid-2col,
.cr-grid-3col,
.cr-grid-4col,
.cr-grid-list,
.cr-grid-magazine {
    --cr-card-gap: var(--wp--preset--spacing--40, 1.5rem);
}

/* ---------- Scope media containers (CSS-004: solo patterns crtheme, no global) ---------- */

.cr-badge-card .cr-badge-card__media,
.cr-grid-hero .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-single__related-image {
    position: relative;
    /* D-122: overflow:hidden clipea el transform:scale del zoom UX en hover. */
    overflow: hidden;
}

/* UX-R1 FIX#1: badge "FUNDAMENTOS" flotaba a la izquierda del documento porque
   .cr-single__related-badge usa position:absolute pero su wrapper .wp-block-post
   (item del post-template) no tenÃ­a position:relative. Lo aÃ±adimos SOLO scoped
   al related-posts de single â€” no global, para no alterar otros layouts. */
.cr-single__related > .wp-block-post,
.cr-single__related.cr-single__related > .wp-block-post {
    position: relative;
}

/* PAT-013 a11y bloqueante: gradient overlay garantiza contraste del badge
   sobre imÃ¡genes featured arbitrarias. D-121: cr-grid-list excluido porque
   su badge va al body (flex horizontal), no sobre el thumb. */
.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(0, 0, 0, 0.25) 0%, transparent 50%);
    pointer-events: none;
    z-index: 1;
}

/* ---------- Badge overlay (sobre featured-image en grids con vertical card) ---------- */

.cr-badge-card__badge,
.cr-grid-hero__badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-archive__badge,
.cr-single__related-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    padding: 6px 10px;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    /* D-140 (Ronda 2 Fix 7): font-size con token xs (0.75rem) + fallback. */
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    /* UX-R3 Fix#1: versalitas REALES via OpenType (smcp/c2sc) â€” Bodoni Moda y
       Mulish (Google Fonts) las soportan. Fallback gracioso a uppercase si la
       fuente no las tiene. */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    border-radius: 2px;
    text-decoration: none;
    line-height: 1.2;
    /* PAT-013: text-shadow refuerza legibilidad contra cualquier imagen de fondo
       que filtre por el badge. */
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

.cr-badge-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty {
    /* EDGE-002: post sin categorÃ­as asignadas â†’ badge vacÃ­o â†’ ocultar
       en lugar de mostrar un cuadrado vinotinto sin texto. */
    display: none;
}

.cr-badge-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-archive__badge a,
.cr-single__related-badge a {
    color: inherit;
    text-decoration: none;
}

/* ---------- D-121: Badge pill inline (sin position:absolute) â€” para layouts
   donde el badge NO va sobre la imagen: cr-grid-list (flex horizontal,
   badge en body), cr-search (idem), cr-single__category (header del
   artÃ­culo, sin imagen contigua). ---------- */

.cr-grid-list__badge,
.cr-search__badge,
.cr-single__category {
    display: inline-block;
    padding: 4px 9px;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    /* D-140 (Ronda 2 Fix 7): token xs (0.75rem) en vez de 11px hardcoded. */
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    /* UX-R3 Fix#1: versalitas reales (smcp/c2sc). */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    border-radius: 2px;
    text-decoration: none;
    line-height: 1.3;
    margin-bottom: 8px;
}

.cr-grid-list__badge a,
.cr-search__badge a,
.cr-single__category a {
    color: inherit;
    text-decoration: none;
}

.cr-grid-list__badge:empty,
.cr-search__badge:empty,
.cr-single__category:empty {
    /* EDGE-002: idem overlay â€” ocultar pill vacÃ­o. */
    display: none;
}

/* ---------- Author card (cr-author-card) ---------- */

.cr-author-card {
    align-items: flex-start;
    gap: var(--wp--preset--spacing--30, 1rem);
}

.cr-author-card__avatar {
    flex-shrink: 0;
}

.cr-author-card__avatar img {
    border-radius: 50%;
    display: block;
}

.cr-author-card__body {
    flex: 1 1 auto;
    min-width: 0;
}

.cr-author-card__name a {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-weight: 700;
    color: var(--wp--preset--color--text-strong, #000000);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.15s ease;
}

.cr-author-card__name a:hover,
.cr-author-card__name a:focus-visible {
    border-bottom-color: var(--wp--preset--color--primary, #89100F);
}

.cr-author-card__bio {
    color: var(--wp--preset--color--text, #202020);
    margin: 0;
}

/* ---------- Share buttons (cr-share-buttons) ---------- */

.cr-share-buttons {
    margin: var(--wp--preset--spacing--40, 1.5rem) 0;
    flex-wrap: wrap;
    gap: 8px;
}

.cr-share-buttons__btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: var(--wp--preset--color--bg-soft, #FCF7F7);
    color: var(--wp--preset--color--text, #202020);
    border: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    border-radius: 2px;
    /* D-140 (Ronda 2 Fix 7): token sm (0.875rem) en vez de 14px. */
    font-size: var(--wp--preset--font-size--sm, 0.875rem);
    font-weight: 500;
    text-decoration: none;
    cursor: pointer;
    transition: background 0.15s ease, color 0.15s ease;
    font-family: inherit;
}

.cr-share-buttons__btn:hover,
.cr-share-buttons__btn:focus-visible {
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    outline: none;
}

.cr-share-buttons__btn:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
}

.cr-share-buttons__btn svg {
    flex-shrink: 0;
}

/* Texto sÃ³lo para lectores de pantalla (PAT-021). */
.screen-reader-text {
    position: absolute !important;
    clip: rect(1px, 1px, 1px, 1px);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    width: 1px;
    word-wrap: normal !important;
}

/* ---------- Grid list (cr-grid-list) â€” vista horizontal ---------- */

.cr-grid-list__items > * {
    margin-bottom: var(--cr-card-gap);
    padding-bottom: var(--cr-card-gap);
    border-bottom: 1px solid var(--wp--preset--color--rule, #E8EBEE);
}

.cr-grid-list__item {
    gap: var(--wp--preset--spacing--30, 1rem);
}

.cr-grid-list .cr-grid-list__thumb {
    flex-shrink: 0;
    width: 200px;
    max-width: 30%;
}

.cr-grid-list__body {
    flex: 1 1 auto;
    min-width: 0;
}

@media (max-width: 600px) {
    .cr-grid-list__item {
        flex-direction: column;
    }

    .cr-grid-list .cr-grid-list__thumb {
        width: 100%;
        max-width: 100%;
    }
}

/* ---------- Grid magazine (cr-grid-magazine) â€” composiciÃ³n asimÃ©trica ---------- */

.cr-grid-magazine__hero,
.cr-grid-magazine__mid {
    margin-bottom: var(--cr-card-gap);
}

/* ---------- Grid responsive (mobile-first) ---------- */
/* PAT-007: incluido cr-grid-hero__rest en breakpoints mobile/tablet. */

@media (max-width: 600px) {
    .cr-grid-2col .wp-block-post-template,
    .cr-grid-3col .wp-block-post-template,
    .cr-grid-4col .wp-block-post-template,
    .cr-grid-hero__rest .wp-block-post-template,
    .cr-grid-magazine__mid .wp-block-post-template,
    .cr-grid-magazine__small .wp-block-post-template,
    .cr-archive .wp-block-post-template {
        grid-template-columns: 1fr !important;
    }
}

@media (min-width: 601px) and (max-width: 900px) {
    .cr-grid-3col .wp-block-post-template,
    .cr-grid-4col .wp-block-post-template,
    .cr-grid-hero__rest .wp-block-post-template,
    .cr-grid-magazine__small .wp-block-post-template,
    .cr-archive .wp-block-post-template {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ---------- prefers-reduced-motion (a11y WCAG 2.3.3) ---------- */

@media (prefers-reduced-motion: reduce) {
    .cr-share-buttons__btn,
    .cr-author-card__name a {
        transition: none;
    }
}

/* ---------- D-118: mÃ¡ximo 900px en heroes para preservar nitidez de las
   imÃ¡genes legacy 900Ã—537. WP no upscalea; un img a 100% width estirado a
   1200px (wideSize) se ve borroso. Limitamos el contenedor visual y
   centramos. Bloque al final del archivo por orden de specificity
   (stylelint no-descending-specificity). ---------- */
.cr-single__hero,
.cr-grid-hero__featured .wp-block-post-featured-image {
    max-width: 900px;
    margin-inline: auto;
    display: block;
}

.cr-single__hero img,
.cr-grid-hero__featured .wp-block-post-featured-image img {
    width: 100%;
    height: auto;
    display: block;
}

/* ---------- D-119: header (cr-header) â€” site-logo + nav con overlay mobile.
   El bloque core/navigation soporta overlayMenu="mobile" out-of-the-box
   (hamburger automÃ¡tico). AquÃ­ solo estilizamos el inner flex + el icon. ---------- */

.cr-header .cr-header__inner {
    padding-block: var(--wp--preset--spacing--30, 1rem);
    gap: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-header .cr-header__logo .custom-logo,
.cr-header .cr-header__logo img {
    height: auto;
    max-height: 64px;
    width: auto;
    display: block;
}

.cr-header .cr-header__nav .wp-block-navigation__responsive-container-open,
.cr-header .cr-header__nav .wp-block-navigation__responsive-container-close {
    color: var(--wp--preset--color--text-strong, #000000);
    /* WCAG 2.5.5: tap target â‰¥44Ã—44px para el icon hamburger. */
    min-width: 44px;
    min-height: 44px;
}

.cr-header .cr-header__nav .wp-block-navigation__responsive-container.is-menu-open {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-header .cr-header__nav .wp-block-navigation-item__content {
    color: var(--wp--preset--color--text-strong, #000000);
    font-weight: 500;
}

/* UX-R1 FIX#2: nav header colapsado a columna vertical en desktop.
   El wp-block-navigation con is-responsive estaba aplicando flex-direction:column
   por algÃºn wrap interno. Forzamos row + nowrap en desktop (â‰¥901px) y dejamos
   que el overlayMenu="mobile" haga su trabajo en â‰¤900px (hamburger automÃ¡tico). */
@media (min-width: 901px) {
    .cr-header .cr-header__nav,
    .cr-header .cr-header__nav .wp-block-navigation__container,
    .cr-header .cr-header__nav .wp-block-navigation__responsive-container,
    .cr-header .cr-header__nav .wp-block-navigation__responsive-container-content {
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center;
    }

    .cr-header .cr-header__nav .wp-block-navigation__container {
        gap: var(--wp--preset--spacing--40, 1.5rem);
        justify-content: flex-end;
    }

    .cr-header .cr-header__nav .wp-block-navigation-item {
        display: inline-flex;
        align-items: center;
    }
}

/* Permitir que el nav ocupe espacio suficiente en el flex del inner para no
   colapsar contra el wordmark cuando Ã©ste es ancho. */
.cr-header .cr-header__inner {
    flex-wrap: nowrap;
}

.cr-header .cr-header__nav {
    flex: 1 1 auto;
    min-width: 0;
}

/* UX-R1 FIX#3: layout 2/3 + 1/3 del single con sidebar reconectada.
   Mobile (â‰¤900px): stack vertical, sidebar despuÃ©s del contenido. */
.cr-single .cr-single__layout {
    gap: var(--wp--preset--spacing--50, 2.25rem);
    margin-block-start: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-single .cr-single__sidebar-col {
    /* Sticky sidebar en desktop para mantener visible mientras se lee. */
    align-self: flex-start;
}

@media (min-width: 901px) {
    .cr-single .cr-single__sidebar-col {
        position: sticky;
        top: var(--wp--preset--spacing--40, 1.5rem);
    }
}

@media (max-width: 900px) {
    .cr-single .cr-single__layout {
        flex-direction: column;
    }

    .cr-single .cr-single__main-col,
    .cr-single .cr-single__sidebar-col {
        flex-basis: 100% !important;
        width: 100% !important;
    }
}

/* ---------- D-139 (FA03): footer editorial vinotinto â€” emula el footer
   del prod (catolicismoreformado.com). Reemplaza el footer 3-col D-119.
   Stack vertical centrado sobre #89100F sÃ³lido. Mucho white space
   (Teopolis Â§5.3 lÃ­nea visual principal).

   Contraste blanco/vinotinto = 6.94:1 (WCAG AAA â€” supera 4.5:1 AA).
   Iconos sociales SVG inline (D-008 prohÃ­be Font Awesome / SDKs externos).
   ---------- */

.cr-footer {
    padding-block: var(--wp--preset--spacing--60, 4rem) var(--wp--preset--spacing--50, 2.25rem);
    text-align: center;
}

.cr-footer .cr-footer__logo {
    margin: 0 auto var(--wp--preset--spacing--40, 1.5rem);
    max-width: 320px;
}

.cr-footer .cr-footer__logo img {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    height: auto;
    filter: brightness(0) invert(1);
}

.cr-footer .cr-footer__tagline {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-style: italic;
    font-weight: 800;
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    line-height: 1.2;
    letter-spacing: -0.01em;
    text-align: center;
    color: inherit;
    margin: 0 auto var(--wp--preset--spacing--40, 1.5rem);
    max-width: 36ch;
}

.cr-footer .cr-footer__social {
    display: flex;
    flex-direction: row;
    gap: var(--wp--preset--spacing--40, 1.5rem);
    justify-content: center;
    align-items: center;
    margin: var(--wp--preset--spacing--40, 1.5rem) auto;
    padding: 0;
    list-style: none;
}

.cr-footer .cr-footer__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
    color: inherit;
    text-decoration: none;
    opacity: 0.85;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.cr-footer .cr-footer__social-link:hover,
.cr-footer .cr-footer__social-link:focus-visible {
    opacity: 1;
    transform: translateY(-2px);
}

.cr-footer .cr-footer__social-link:focus-visible {
    outline: 2px solid var(--wp--preset--color--on-primary, #FFFFFF);
    outline-offset: 4px;
    border-radius: 2px;
}

.cr-footer .cr-footer__social-icon {
    display: block;
    width: 22px;
    height: 22px;
    color: inherit;
    fill: currentColor;
}

.cr-footer .cr-footer__nav,
.cr-footer .wp-block-navigation.cr-footer__nav {
    margin: var(--wp--preset--spacing--40, 1.5rem) auto var(--wp--preset--spacing--30, 1rem);
    justify-content: center;
    /* UX-R3 Fix#1: versalitas reales completas (smcp + c2sc + variant). */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.85rem;
    font-weight: 500;
}

.cr-footer .cr-footer__nav .wp-block-navigation-item__content,
.cr-footer .cr-footer__nav a {
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    text-decoration: none;
    padding: 0.5rem 0.75rem;
    transition: opacity 0.3s ease;
    opacity: 0.85;
}

.cr-footer .cr-footer__nav .wp-block-navigation-item__content:hover,
.cr-footer .cr-footer__nav a:hover,
.cr-footer .cr-footer__nav .wp-block-navigation-item__content:focus-visible,
.cr-footer .cr-footer__nav a:focus-visible {
    opacity: 1;
    text-decoration: none;
    color: var(--wp--preset--color--on-primary, #FFFFFF);
}

.cr-footer .cr-footer__nav a:focus-visible {
    outline: 2px solid var(--wp--preset--color--on-primary, #FFFFFF);
    outline-offset: 2px;
    border-radius: 2px;
}

.cr-footer .cr-footer__copyright {
    text-align: center;
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    /* UX-R3 Fix#1: versalitas reales completas. */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.06em;
    font-size: 0.8rem;
    color: inherit;
    opacity: 0.65;
    margin: var(--wp--preset--spacing--40, 1.5rem) auto 0;
    padding-top: var(--wp--preset--spacing--40, 1.5rem);
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    max-width: 640px;
}

@media (prefers-reduced-motion: reduce) {
    .cr-footer .cr-footer__social-link,
    .cr-footer .cr-footer__nav a,
    .cr-footer .cr-footer__nav .wp-block-navigation-item__content {
        transition: none;
    }

    .cr-footer .cr-footer__social-link:hover,
    .cr-footer .cr-footer__social-link:focus-visible {
        transform: none;
    }
}

@media (max-width: 600px) {
    .cr-footer .cr-footer__tagline {
        font-size: 1.5rem;
        max-width: 24ch;
    }

    .cr-footer .cr-footer__social {
        gap: var(--wp--preset--spacing--30, 1rem);
    }

    .cr-footer .cr-footer__nav {
        gap: 0.5rem 1rem;
    }
}

/* Legacy D-119: separator y copy (markup viejo). Compat hasta cleanup FA03. */
.cr-footer__sep {
    border: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.15);
    margin-block: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-footer__copy {
    color: inherit;
    opacity: 0.65;
    margin: 0;
}

/* ---------- UX-R7 Fix#1: contraste defensivo footer (WCAG 1.4.3 AA).
   Bug visible en staging: tagline "Una Fe, un SeÃ±or, un Bautismo" e iconos
   sociales renderizando en negro/gris sobre fondo vinotinto #89100F (~2:1).
   Causa: algÃºn plugin legacy (kirki/grafton) o reset global anula
   `color: inherit` / `--wp--preset--color--on-primary`. Forzamos blanco
   con !important sobre TODO el Ã¡rbol .cr-footer para garantizar 6.94:1 AAA.
   ---------- */
.cr-footer,
.cr-footer * {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
}

.cr-footer a {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    opacity: 0.9;
}

.cr-footer a:hover,
.cr-footer a:focus-visible {
    opacity: 1;
    text-decoration: underline;
}

.cr-footer__tagline {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
}

.cr-footer__social svg,
.cr-footer__social-icon {
    fill: currentColor;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
}

.cr-footer__social a,
.cr-footer__social-link {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
}

.cr-footer__copyright {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    border-top-color: rgba(255, 255, 255, 0.2);
}

.cr-footer__nav a,
.cr-footer__nav .wp-block-navigation-item__content {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-feature-settings: "smcp" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
}

/* ---------- D-120: cr-search resultados â€” layout horizontal en â‰¥601px,
   stack vertical en mobile (espeja cr-grid-list). Sin esto el thumb 200px
   fijo se aprieta contra el texto en mobile <600px. ---------- */

.cr-search .cr-search__item {
    gap: var(--wp--preset--spacing--30, 1rem);
    margin-bottom: var(--cr-card-gap, 1.5rem);
    padding-bottom: var(--cr-card-gap, 1.5rem);
    border-bottom: 1px solid var(--wp--preset--color--rule, #E8EBEE);
}

.cr-search .cr-search__thumb {
    flex-shrink: 0;
    width: 200px;
    max-width: 30%;
}

.cr-search .cr-search__body {
    flex: 1 1 auto;
    min-width: 0;
}

/* ---------- D-120: 404 recent items â€” mantener horizontal pero
   responsive (thumb 120px ya es estrecho, no requiere stack pero sÃ­
   max-width para evitar overflow en viewports <360px). ---------- */

.cr-404__recent-item {
    gap: var(--wp--preset--spacing--30, 1rem);
}

.cr-404__recent-item .wp-block-post-featured-image {
    flex-shrink: 0;
    max-width: 35%;
}

.cr-404__recent-body {
    flex: 1 1 auto;
    min-width: 0;
}

/* ---------- D-119: share-buttons tap target en mobile (WCAG 2.5.5). ---------- */

@media (max-width: 600px) {
    .cr-share-buttons__btn {
        min-height: 44px;
        padding: 12px 16px;
    }

    /* D-120: search en mobile â€” stack vertical (thumb 100%). */
    .cr-search .cr-search__item {
        flex-direction: column;
    }

    .cr-search .cr-search__thumb {
        width: 100%;
        max-width: 100%;
    }

    /* Footer en mobile: stack vertical de columnas con menor gap. */
    .cr-footer__cols {
        gap: var(--wp--preset--spacing--40, 1.5rem);
    }
}

/* ---------- D-121: focus-visible global para enlaces dentro de cards/grids
   (WCAG 2.4.7 Focus Visible AA). Al final del archivo para evitar conflictos
   no-descending-specificity con .cr-author-card__name a:focus-visible. ---------- */

/* Doble clase para empatar specificity con .cr-footer .cr-footer__list a:hover
   (0,3,1) y respetar stylelint no-descending-specificity. */
.cr-grid-hero.cr-grid-hero a:focus-visible,
.cr-grid-2col.cr-grid-2col a:focus-visible,
.cr-grid-3col.cr-grid-3col a:focus-visible,
.cr-grid-4col.cr-grid-4col a:focus-visible,
.cr-grid-list.cr-grid-list a:focus-visible,
.cr-grid-magazine.cr-grid-magazine a:focus-visible,
.cr-badge-card.cr-badge-card a:focus-visible,
.cr-archive.cr-archive a:focus-visible,
.cr-search.cr-search a:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
    border-radius: 2px;
}

/* ---------- D-122: hover micro-interactions en cards (UX afford visual de
   clickeable). Antes solo author-card y share-buttons tenÃ­an :hover, las
   cards de los grids eran completamente estÃ¡ticas. Subtle por diseÃ±o
   editorial â€” color cambio en title + zoom suave en imagen.
   `prefers-reduced-motion` desactiva el zoom (ya cubierto al final). ---------- */

/* UX needs-fix #1 (transition desync): transition fuera del :hover para que
   tanto enter como leave usen la misma duraciÃ³n (0.4s) que el zoom de imagen. */
.cr-grid-hero.cr-grid-hero .wp-block-post-title a,
.cr-grid-2col.cr-grid-2col .wp-block-post-title a,
.cr-grid-3col.cr-grid-3col .wp-block-post-title a,
.cr-grid-4col.cr-grid-4col .wp-block-post-title a,
.cr-grid-list.cr-grid-list .wp-block-post-title a,
.cr-grid-magazine.cr-grid-magazine .wp-block-post-title a,
.cr-badge-card.cr-badge-card .wp-block-post-title a,
.cr-archive.cr-archive .wp-block-post-title a,
.cr-search.cr-search .wp-block-post-title a,
.cr-single .wp-block-post-template .wp-block-post-title a {
    transition: color 0.4s ease, transform 0.4s ease;
}

.cr-grid-hero.cr-grid-hero .wp-block-post-title a:hover,
.cr-grid-2col.cr-grid-2col .wp-block-post-title a:hover,
.cr-grid-3col.cr-grid-3col .wp-block-post-title a:hover,
.cr-grid-4col.cr-grid-4col .wp-block-post-title a:hover,
.cr-grid-list.cr-grid-list .wp-block-post-title a:hover,
.cr-grid-magazine.cr-grid-magazine .wp-block-post-title a:hover,
.cr-badge-card.cr-badge-card .wp-block-post-title a:hover,
.cr-archive.cr-archive .wp-block-post-title a:hover,
.cr-search.cr-search .wp-block-post-title a:hover,
.cr-single .wp-block-post-template .wp-block-post-title a:hover {
    color: var(--wp--preset--color--primary, #89100F);
}

/* Zoom sutil en la imagen al hover del card completo. Doble clase para
   specificity > .cr-grid-hero__featured .wp-block-post-featured-image img
   (D-118 max-width 900px). */
.cr-grid-hero.cr-grid-hero .wp-block-post-featured-image img,
.cr-grid-2col.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine.cr-grid-magazine .wp-block-post-featured-image img,
.cr-badge-card.cr-badge-card .cr-badge-card__media img,
.cr-archive.cr-archive .wp-block-post-featured-image img,
.cr-single.cr-single .cr-single__related-image img {
    transition: transform 0.4s ease;
}

.cr-grid-hero.cr-grid-hero .wp-block-post-featured-image:hover img,
.cr-grid-2col.cr-grid-2col .wp-block-post-featured-image:hover img,
.cr-grid-3col.cr-grid-3col .wp-block-post-featured-image:hover img,
.cr-grid-4col.cr-grid-4col .wp-block-post-featured-image:hover img,
.cr-grid-magazine.cr-grid-magazine .wp-block-post-featured-image:hover img,
.cr-badge-card.cr-badge-card .cr-badge-card__media:hover img,
.cr-archive.cr-archive .wp-block-post-featured-image:hover img,
.cr-single.cr-single .cr-single__related-image:hover img {
    transform: scale(1.04);
}

/* prefers-reduced-motion (WCAG 2.3.3): desactiva zoom + transiciÃ³n. */
@media (prefers-reduced-motion: reduce) {
    .cr-grid-hero.cr-grid-hero .wp-block-post-featured-image img,
    .cr-grid-2col.cr-grid-2col .wp-block-post-featured-image img,
    .cr-grid-3col.cr-grid-3col .wp-block-post-featured-image img,
    .cr-grid-4col.cr-grid-4col .wp-block-post-featured-image img,
    .cr-grid-magazine.cr-grid-magazine .wp-block-post-featured-image img,
    .cr-badge-card.cr-badge-card .cr-badge-card__media img,
    .cr-archive.cr-archive .wp-block-post-featured-image img,
    .cr-single.cr-single .cr-single__related-image img {
        transition: none;
    }

    .cr-grid-hero.cr-grid-hero .wp-block-post-featured-image:hover img,
    .cr-grid-2col.cr-grid-2col .wp-block-post-featured-image:hover img,
    .cr-grid-3col.cr-grid-3col .wp-block-post-featured-image:hover img,
    .cr-grid-4col.cr-grid-4col .wp-block-post-featured-image:hover img,
    .cr-grid-magazine.cr-grid-magazine .wp-block-post-featured-image:hover img,
    .cr-badge-card.cr-badge-card .cr-badge-card__media:hover img,
    .cr-archive.cr-archive .wp-block-post-featured-image:hover img,
    .cr-single.cr-single .cr-single__related-image:hover img {
        transform: none;
    }
}

/* ---------- D-123: cr-slider â€” carrusel CSS-only por categorÃ­as
   (configurables desde el wp:query block del editor). scroll-snap nativo,
   sin JS, sin autoplay (WCAG 2.2.2 Pause Stop Hide). Keyboard accessible
   vÃ­a scroll del browser. Cada slide ocupa fracciÃ³n del viewport segÃºn
   breakpoint (3-up desktop / 2-up tablet / 1.x-up mobile peek). ---------- */

.cr-slider {
    padding-block: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-slider__heading {
    margin: 0 0 var(--wp--preset--spacing--20, 0.5rem);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
}

.cr-slider__hint {
    color: var(--wp--preset--color--muted-strong, #666666);
    margin: 0 0 var(--wp--preset--spacing--30, 1rem);
}

.cr-slider .cr-slider__track {
    display: flex !important;
    flex-wrap: nowrap;
    list-style: none;
    padding: 0 0 12px;
    margin: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: var(--wp--preset--spacing--40, 1.5rem);
    scrollbar-width: thin;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) transparent;
    /* Scroll suave excepto si el usuario tiene reduced-motion. */
    scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {
    .cr-slider .cr-slider__track {
        scroll-behavior: auto;
    }
}

/* Webkit scrollbar (Chrome/Safari): match scrollbar-color. */
.cr-slider .cr-slider__track::-webkit-scrollbar {
    height: 8px;
}

.cr-slider .cr-slider__track::-webkit-scrollbar-thumb {
    background: var(--wp--preset--color--primary, #89100F);
    border-radius: 4px;
}

.cr-slider .cr-slider__track::-webkit-scrollbar-track {
    background: var(--wp--preset--color--bg-soft, #FCF7F7);
    border-radius: 4px;
}

.cr-slider .cr-slider__track > li {
    flex: 0 0 calc(33.333% - 1rem);
    scroll-snap-align: start;
    min-width: 0;
    margin: 0;
    list-style: none;
    position: relative;
}

@media (max-width: 900px) {
    .cr-slider .cr-slider__track > li {
        flex: 0 0 calc(50% - 0.5rem);
    }
}

@media (max-width: 600px) {
    .cr-slider .cr-slider__track > li {
        /* Mobile peek: 85% del viewport para que asome la siguiente slide
           y comunique visualmente "hay mÃ¡s a la derecha". */
        flex: 0 0 85%;
    }
}

/* La imagen del slide hereda el setup overlay (position:relative +
   overflow:hidden) si fuera necesario. AquÃ­ aÃ±adimos position:relative
   al __media para que el badge overlay funcione. */
.cr-slider__media {
    position: relative;
    overflow: hidden;
}

.cr-slider.cr-slider.cr-slider .cr-slider__media img {
    transition: transform 0.4s ease;
}

.cr-slider.cr-slider.cr-slider .cr-slider__media:hover img {
    transform: scale(1.04);
}

@media (prefers-reduced-motion: reduce) {
    .cr-slider.cr-slider.cr-slider .cr-slider__media img {
        transition: none;
    }

    .cr-slider.cr-slider.cr-slider .cr-slider__media:hover img {
        transform: none;
    }
}

/* Badge overlay sobre la imagen del slide (mismo estilo que el resto). */
.cr-slider__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    padding: 6px 10px;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    /* D-140 (Ronda 2 Fix 7): token xs en vez de 11px hardcoded. */
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    /* UX-R3 Fix#1: versalitas reales (smcp/c2sc). */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    border-radius: 2px;
    text-decoration: none;
    line-height: 1.2;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

.cr-slider__badge:empty {
    display: none;
}

.cr-slider.cr-slider.cr-slider .cr-slider__badge a {
    color: inherit;
    text-decoration: none;
}

/* focus-visible global del slider â€” doble clase para empatar specificity
   con .cr-footer .cr-footer__list a:hover y resto del archivo. */
.cr-slider.cr-slider.cr-slider a:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
    border-radius: 2px;
}

.cr-slider.cr-slider.cr-slider .wp-block-post-title a {
    transition: color 0.4s ease, transform 0.4s ease;
}

.cr-slider.cr-slider.cr-slider .wp-block-post-title a:hover {
    color: var(--wp--preset--color--primary, #89100F);
}

/* ---------- D-124: feature toggles â€” overrides condicionales por body class.
   CR_Settings::filter_body_class aÃ±ade `cr-feature-disabled-<key>` al <body>
   cuando una feature estÃ¡ OFF. Estas reglas overridean los efectos visuales
   correspondientes.

   Bloques estructurales (single sections, footer columns) se ocultan vÃ­a
   pre_render_block en PHP (no se emite HTML). AquÃ­ solo cubrimos:
   - micro-interactions UX (hover-zoom, title-hover-color) que sÃ­ emiten HTML.

   Important: !important justificado porque sobreescribimos reglas con doble
   o triple clase de specificity (D-122 zoom hover). Stylelint disable porque
   semÃ¡nticamente estos overrides DEBEN ir al final del archivo (override
   pattern); el orden lexical es intencional. ---------- */
/* stylelint-disable no-descending-specificity */

body.cr-feature-disabled-hover-zoom .wp-block-post-featured-image img,
body.cr-feature-disabled-hover-zoom .cr-slider__media img {
    transition: none !important;
}

body.cr-feature-disabled-hover-zoom .wp-block-post-featured-image:hover img,
body.cr-feature-disabled-hover-zoom .cr-slider__media:hover img,
body.cr-feature-disabled-hover-zoom .cr-badge-card__media:hover img,
body.cr-feature-disabled-hover-zoom .cr-single__related-image:hover img {
    transform: none !important;
}

body.cr-feature-disabled-title-hover-color .wp-block-post-title a:hover {
    color: inherit !important;
    transition: none !important;
}

/* Site-logo fallback styling cuando se reemplaza por site-title. */
.cr-site-title-fallback {
    margin: 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-weight: 700;
    font-size: 1.25rem;
}

.cr-site-title-fallback a {
    color: var(--wp--preset--color--text-strong, #000000);
    text-decoration: none;
}

.cr-site-title-fallback a:hover {
    color: var(--wp--preset--color--primary, #89100F);
}

/* ---------- D-129 + D-130: wordmark bicromÃ¡tico (audit Â§1.1) ---------- */
/* Split CATOLICISMO (text-strong negro) + REFORMADO (primary vinotinto) en
   tipografÃ­a display (Bodoni Moda). Aplicable a header y footer. */

.cr-header__brand,
.cr-footer__brand {
    display: inline-flex;
    align-items: baseline;
    gap: 0.4em;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-weight: 700;
    letter-spacing: 0.02em;
    text-decoration: none;
    line-height: 1;
    margin: 0;
}

.cr-header__brand {
    font-size: clamp(1.5rem, 2.5vw, 2.25rem);
}

.cr-footer__brand {
    font-size: 1.5rem;
    margin-bottom: 0.5rem;
}

.cr-header__brand-line {
    display: inline-flex;
    gap: 0.4em;
}

.cr-header__brand-word--first,
.cr-footer__brand-word--first {
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-header__brand-word--second,
.cr-footer__brand-word--second {
    color: var(--wp--preset--color--primary, #89100F);
}

.cr-header__brand:hover .cr-header__brand-word--first,
.cr-header__brand:focus-visible .cr-header__brand-word--first {
    color: var(--wp--preset--color--primary, #89100F);
}

.cr-header__brand:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 4px;
}

/* Tagline confesional "Una Fe, un SeÃ±or, un Bautismo" (audit Â§1.1 + Â§1.4). */
.cr-footer__tagline {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-style: italic;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: 0.875rem;
    letter-spacing: 0.05em;
    margin: 0 0 1rem;
}

.cr-footer__desc {
    color: var(--wp--preset--color--muted-strong, #666666);
    margin: 0;
}

@media (max-width: 600px) {
    .cr-header__brand {
        font-size: 1.25rem;
    }
    .cr-header__brand-line {
        flex-wrap: wrap;
        gap: 0.2em;
    }
}

/* ---------- D-131 (gap 3, audit Â§5.4): card meta â€” autor + fecha + reading
   time en versalitas (Mere Orthodoxy). Reutilizable en todos los grids. ---------- */

.cr-card__meta {
    align-items: center;
    gap: 0.5em 0.85em;
    margin-top: 0.5rem;
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--wp--preset--color--muted-strong, #666666);
    text-transform: uppercase;
    /* UX-R3 Fix#1: versalitas reales (smcp/c2sc) â€” meta de cards en versalitas
       tipogrÃ¡ficas reales, no fake-uppercase mecÃ¡nico. */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    line-height: 1.4;
}

.cr-card__meta .wp-block-post-author-name,
.cr-card__meta .cr-card__author {
    color: var(--wp--preset--color--text-strong, #000000);
    font-weight: 700;
}

.cr-card__meta .wp-block-post-author-name a,
.cr-card__meta .cr-card__author a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.15s ease;
}

.cr-card__meta .wp-block-post-author-name a:hover,
.cr-card__meta .cr-card__author a:hover {
    border-bottom-color: var(--wp--preset--color--primary, #89100F);
}

.cr-card__meta .wp-block-post-date,
.cr-card__meta .cr-card__date {
    color: var(--wp--preset--color--muted-strong, #666666);
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: none;
}

.cr-card__meta .cr-reading-time {
    color: var(--wp--preset--color--muted-strong, #666666);
    font-weight: 500;
    letter-spacing: 0.04em;
    text-transform: none;
}

/* ---------- D-132 (gap 5, audit Â§5.3 + Â§5.2): hero asimÃ©trico â€” lead 2/3 +
   rail 1/3 vertical. Refuerza "peso editorial visible". ---------- */

.cr-grid-hero__cols {
    gap: var(--wp--preset--spacing--50, 2.25rem);
    margin-block: var(--wp--preset--spacing--50, 2.25rem);
}

.cr-grid-hero__lead-col .wp-block-post-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.015em;
    margin: 0.5em 0 0.4em;
}

.cr-grid-hero__lead-col .cr-grid-hero__title {
    font-size: clamp(2rem, 4vw, 3.25rem);
}

.cr-grid-hero__lead-col .wp-block-post-excerpt {
    font-size: 1.0625rem;
    line-height: 1.55;
    color: var(--wp--preset--color--text, #202020);
    margin-top: 0.75rem;
    max-width: 60ch;
}

.cr-grid-hero__rail .wp-block-post-template {
    display: flex !important;
    flex-direction: column;
    gap: 1.5rem;
}

.cr-grid-hero__rail-item {
    padding-bottom: 1.25rem;
    border-bottom: 1px solid var(--wp--preset--color--rule, #E8EBEE);
}

.cr-grid-hero__rail-item:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.cr-grid-hero__rail-image {
    margin-bottom: 0.5rem;
}

.cr-grid-hero__rail-title {
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    font-size: 1rem;
    font-weight: 600;
    line-height: 1.3;
    margin: 0.25rem 0;
}

@media (max-width: 900px) {
    .cr-grid-hero__cols {
        flex-direction: column;
    }
    .cr-grid-hero__lead-col,
    .cr-grid-hero__rail-col {
        flex-basis: 100% !important;
        width: 100% !important;
    }
}

/* ---------- D-133 (gap 7, audit Â§1.2 + Â§5.3): bg-soft alternado en
   secciones de home â€” rompe la planicie blanca con respeto editorial. ---------- */

.cr-home > .cr-section-soft {
    background-color: var(--wp--preset--color--bg-soft, #FCF7F7);
    padding-block: var(--wp--preset--spacing--60, 4rem);
    /* Romper el constrained layout para que el bg se extienda a borde. */
    margin-inline: calc(-1 * var(--wp--style--root--padding-right, 1.5rem));
    padding-inline: var(--wp--style--root--padding-right, 1.5rem);
}

.cr-home__post-main .cr-section-soft {
    margin-inline: 0;
}

/* ---------- D-134 (gap 6, audit Â§5.3): divisores minimalistas â€” separator
   con color rule + margin grande, da respiro editorial entre secciones. ---------- */

.cr-rule,
.wp-block-separator.cr-rule {
    border: 0;
    border-top: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    margin-block: var(--wp--preset--spacing--60, 4rem);
    background: none;
    opacity: 1;
    max-width: 100%;
    width: 100%;
    height: 0;
}

/* ---------- D-135 (gap 9, audit Â§1.1 + UX): badge limitado a 1 sola
   categoria â€” first child del wp:post-terms para evitar "ANGLICANISMO, RECURSOS,..." truncado. ---------- */

.cr-badge-card__badge,
.cr-grid-hero__badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-grid-list__badge,
.cr-search__badge {
    /* Truncate visual: max-width + ellipsis si tiene 2+ categorias.
       El "preferred fix" seria solo mostrar 1, pero ese cambio requiere
       PHP override del post-terms render. Esta es la mitigacion CSS. */
    max-width: 70%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Si hay multiples links separados por coma, ocultar a partir del segundo. */
.cr-badge-card__badge a:nth-child(n+2),
.cr-grid-hero__badge a:nth-child(n+2),
.cr-grid-2col__badge a:nth-child(n+2),
.cr-grid-3col__badge a:nth-child(n+2),
.cr-grid-4col__badge a:nth-child(n+2),
.cr-grid-magazine__badge a:nth-child(n+2),
.cr-archive__badge a:nth-child(n+2),
.cr-single__related-badge a:nth-child(n+2),
.cr-grid-list__badge a:nth-child(n+2),
.cr-search__badge a:nth-child(n+2) {
    display: none;
}

/* WP renderiza ", " entre terms â€” ocultar la coma residual visualmente */
.cr-badge-card__badge,
.cr-grid-hero__badge,
.cr-grid-3col__badge {
    /* white-space:nowrap ya cubre. Sin la coma se ve raro si es text node;
       este selector mantiene el badge limpio limitando ancho a 1 termino. */
}

/* ---------- D-136 (gap 8, audit Â§5.1): podcast CTA minimalista
   (White Horse Inn "CTA prominente de suscripcion al podcast"). ---------- */

.cr-podcast-cta {
    background: var(--wp--preset--color--bg-soft, #FCF7F7);
    border-top: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    border-bottom: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    padding-block: var(--wp--preset--spacing--60, 4rem);
    margin-block: var(--wp--preset--spacing--50, 2.25rem);
}

.cr-podcast-cta__inner {
    text-align: center;
    max-width: 600px;
    margin-inline: auto;
}

.cr-podcast-cta__heading {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 800;
    color: var(--wp--preset--color--text-strong, #000000);
    margin: 0 0 0.5rem;
    line-height: 1.15;
}

.cr-podcast-cta__sub {
    color: var(--wp--preset--color--muted-strong, #666666);
    margin: 0 0 1.5rem;
}

.cr-podcast-cta__button {
    display: inline-block;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    padding: 0.85rem 2rem;
    border-radius: 2px;
    text-decoration: none;
    font-weight: 600;
    text-transform: uppercase;
    /* UX-R3 Fix#1: versalitas reales (smcp/c2sc). */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.875rem;
    transition: background 0.15s ease, transform 0.15s ease;
}

.cr-podcast-cta__button:hover,
.cr-podcast-cta__button:focus-visible {
    background: var(--wp--preset--color--text-strong, #000000);
    outline: none;
    transform: translateY(-1px);
}

.cr-podcast-cta__button:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 3px;
}

/* ---------- D-137: footer tipografia editorial (post wordmark + tagline) ---------- */




/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* UXR16: explicit Gutenberg content-size escape for premium home modules. */
.cr-home.wp-block-group.is-layout-constrained > :is(
    .cr-home-slider,
    .cr-trending,
    .cr-spotlight-mosaic,
    .cr-issue-list,
    .cr-text-grid-section,
    .cr-slider-pdfs
) {
    width: var(--cr-visual-wide, min(1180px, calc(100vw - 48px))) !important;
    max-width: var(--cr-visual-wide, min(1180px, calc(100vw - 48px))) !important;
    margin-inline: auto !important;
}

.cr-home-slider.wp-block-group.is-layout-constrained > :is(
    .cr-home-slider__header,
    .cr-home-slider__query
),
.cr-trending.wp-block-group.is-layout-constrained > :is(
    .cr-trending__header,
    .cr-trending__layout
) {
    width: 100% !important;
    max-width: none !important;
    margin-inline: 0 !important;
}

.cr-home-slider > .wp-block-query.cr-home-slider__query,
.cr-home-slider__query,
.cr-home-slider__track {
    width: 100% !important;
    max-width: none !important;
}

.cr-home-slider .cr-home-slider__track.wp-block-post-template {
    display: flex !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
    max-width: none !important;
    overflow-x: auto;
}

.cr-home-slider .cr-home-slider__track.wp-block-post-template > li {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    width: auto !important;
    max-width: none !important;
}

.cr-trending > .cr-trending__layout,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid {
    width: 100% !important;
    max-width: none !important;
}

.cr-home-slider__image,
.cr-home-slider__image a,
.cr-home-slider__image img,
.cr-trending__feature-image,
.cr-trending__feature-image a,
.cr-trending__feature-image img,
.cr-trending__mini-image,
.cr-trending__mini-image a,
.cr-trending__mini-image img {
    width: 100% !important;
    max-width: none !important;
}

@media (max-width: 900px) {
    .cr-home-slider .cr-home-slider__track.wp-block-post-template > li {
        flex: 0 0 calc((100% - 1rem) / 2) !important;
    }
}

@media (max-width: 600px) {
    .cr-home-slider .cr-home-slider__track.wp-block-post-template > li {
        flex: 0 0 86% !important;
    }
}

/* stylelint-enable no-descending-specificity */

/* ---------- D-138 (F32+F33 final polish): a11y + UX micro-fixes ---------- */
/* stylelint-disable no-descending-specificity */

/* A11y MEDIUM (F32 #2): logo aspect-ratio para prevenir CLS y mantener ratio. */
.custom-logo,
.cr-header__logo {
    aspect-ratio: 553 / 74;
    max-height: 40px;
    height: auto;
    width: auto;
}

/* A11y MEDIUM (F32 #3): focus-visible en pagination, header-nav y search button.
   Complementa los focus-visible ya cubiertos en grids/cards (D-121). */
.wp-block-query-pagination a:focus-visible,
.wp-block-search button:focus-visible,
header nav a:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
}

/* UX needs-fix #2 (F33 #5): cr-grid-list hover zoom consistente con otras grids.
   No estaba cubierto en D-122 porque la imagen va en flex horizontal, no overlay. */
.cr-grid-list.cr-grid-list .wp-block-post-featured-image img {
    transition: transform 0.4s ease;
}

.cr-grid-list.cr-grid-list .wp-block-post-featured-image:hover img {
    transform: scale(1.04);
}

@media (prefers-reduced-motion: reduce) {
    .cr-grid-list.cr-grid-list .wp-block-post-featured-image img {
        transition: none;
    }
    .cr-grid-list.cr-grid-list .wp-block-post-featured-image:hover img {
        transform: none;
    }
}

/* UX needs-fix #3 (F33 #6): share buttons :active y :disabled.
   .cr-share cubre cualquier wrapper de share + el .cr-share-buttons existente. */
.cr-share button:active,
.cr-share a:active,
.cr-share-buttons__btn:active {
    transform: scale(0.96);
}

.cr-share button:disabled,
.cr-share-buttons__btn:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* UX needs-fix #4 (F33 #7): cr-search__form estilos bÃ¡sicos consistentes con
   el lenguaje editorial (botÃ³n vinotinto, input rule color, focus primary). */
.cr-search__form {
    display: flex;
    gap: 0.5rem;
    max-width: 480px;
}

.cr-search__form input[type="search"] {
    flex: 1;
    padding: 0.75rem 1rem;
    border: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    border-radius: 2px;
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
}

.cr-search__form input[type="search"]:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
    border-color: var(--wp--preset--color--primary, #89100F);
}

.cr-search__form button {
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    border: none;
    padding: 0.75rem 1.5rem;
    border-radius: 2px;
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    font-weight: 600;
    letter-spacing: 0.05em;
    cursor: pointer;
    text-transform: uppercase;
    /* UX-R3 Fix#1: versalitas reales (smcp/c2sc). */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    font-size: 0.85rem;
}

.cr-search__form button:hover {
    background: var(--wp--preset--color--text-strong, #000000);
}

.cr-search__form button:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
}





/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */

/* ---------- D-139 (FA05): cr-slider-pdfs â€” carousel CSS-only de PDFs
   descargables (categorÃ­a "recursos"). Replica el patrÃ³n scroll-snap nativo
   de D-123 (cr-slider-categories) pero con cover 2:3 estilo libro + CTA
   "Descargar PDF". Sin JS, sin autoplay (WCAG 2.2.2 Pause Stop Hide).
   Tres-up desktop / dos-up tablet / mobile peek 85%. ---------- */
/* stylelint-disable no-descending-specificity */

.cr-slider-pdfs {
    padding-block: var(--wp--preset--spacing--60, 4rem);
}

.cr-slider-pdfs .cr-slider-pdfs__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 800;
    letter-spacing: -0.01em;
    margin: 0 0 var(--wp--preset--spacing--20, 0.5rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-slider-pdfs .cr-slider-pdfs__hint {
    color: var(--wp--preset--color--muted-strong, #666666);
    margin: 0 0 var(--wp--preset--spacing--40, 1.5rem);
}

.cr-slider-pdfs .cr-slider-pdfs__track {
    display: flex !important;
    flex-wrap: nowrap;
    list-style: none;
    padding: 0 0 12px;
    margin: 0;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    gap: var(--wp--preset--spacing--40, 1.5rem);
    scrollbar-width: thin;
    scrollbar-color: var(--wp--preset--color--rule, #E8EBEE) transparent;
}

.cr-slider-pdfs .cr-slider-pdfs__track::-webkit-scrollbar {
    height: 8px;
}

.cr-slider-pdfs .cr-slider-pdfs__track::-webkit-scrollbar-thumb {
    background: var(--wp--preset--color--rule, #E8EBEE);
    border-radius: 4px;
}

.cr-slider-pdfs .cr-slider-pdfs__track::-webkit-scrollbar-track {
    background: transparent;
}

.cr-slider-pdfs .cr-slider-pdfs__track > * {
    flex: 0 0 calc((100% - 3rem) / 3);
    scroll-snap-align: start;
    min-width: 0;
    margin: 0;
    list-style: none;
}

@media (max-width: 900px) {
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex: 0 0 calc((100% - 1.5rem) / 2);
    }
}

@media (max-width: 600px) {
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex: 0 0 85%;
    }
}

.cr-slider-pdfs .cr-slider-pdfs__card {
    background: var(--wp--preset--color--bg-soft, #FCF7F7);
    border: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    padding: var(--wp--preset--spacing--40, 1.5rem);
    text-align: center;
    border-radius: 4px;
    transition: transform 0.4s ease, box-shadow 0.4s ease;
    height: 100%;
    display: flex;
    flex-direction: column;
}

.cr-slider-pdfs .cr-slider-pdfs__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(137, 16, 15, 0.08);
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image {
    margin-bottom: var(--wp--preset--spacing--30, 1rem);
    overflow: hidden;
    border-radius: 2px;
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image img {
    aspect-ratio: 2/3;
    object-fit: cover;
    width: 100%;
    height: auto;
    display: block;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
    transition: transform 0.4s ease;
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image:hover img {
    transform: scale(1.04);
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: 1.0625rem;
    font-weight: 600;
    margin: 0.5rem 0;
    line-height: 1.3;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title a {
    color: var(--wp--preset--color--text-strong, #000000);
    text-decoration: none;
    transition: color 0.2s ease;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title a:hover {
    color: var(--wp--preset--color--primary, #89100F);
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    /* UX-R3 Fix#1: versalitas reales completas (smcp + c2sc) + font-variant-caps. */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.75rem;
    color: var(--wp--preset--color--muted-strong, #666666);
    margin-bottom: var(--wp--preset--spacing--30, 1rem);
}

.cr-slider-pdfs .cr-slider-pdfs__author a {
    color: inherit;
    text-decoration: none;
}

.cr-slider-pdfs .cr-slider-pdfs__author a:hover {
    color: var(--wp--preset--color--primary, #89100F);
}

.cr-slider-pdfs .cr-slider-pdfs__cta-wrap {
    margin-top: auto;
}

.cr-slider-pdfs .cr-slider-pdfs__cta .wp-block-button__link {
    display: inline-block;
    padding: 0.75rem 1.5rem;
    /* UX-R3 Fix#1: versalitas reales completas. */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    font-size: 0.85rem;
    font-weight: 600;
    border-radius: 2px;
    transition: background 0.15s ease, transform 0.15s ease;
}

.cr-slider-pdfs .cr-slider-pdfs__cta .wp-block-button__link:hover,
.cr-slider-pdfs .cr-slider-pdfs__cta .wp-block-button__link:focus-visible {
    background: var(--wp--preset--color--text-strong, #000000);
    transform: translateY(-1px);
    outline: none;
}

.cr-slider-pdfs .cr-slider-pdfs__cta .wp-block-button__link:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 3px;
}

.cr-slider-pdfs .cr-slider-pdfs__empty {
    color: var(--wp--preset--color--muted-strong, #666666);
    font-style: italic;
    padding-block: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-slider-pdfs.cr-slider-pdfs .cr-slider-pdfs__track:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 4px;
    border-radius: 2px;
}

.cr-slider-pdfs.cr-slider-pdfs a:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
    border-radius: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .cr-slider-pdfs .cr-slider-pdfs__track {
        scroll-behavior: auto;
    }
}

/* ---------- FIX P0: cr-slider-pdfs especificidad WP block layout ---------- */
/* WP wp-block-post-template-is-layout-flex sobreescribe nuestro flex. Forzamos. */
.cr-slider-pdfs .cr-slider-pdfs__track {
    overflow-x: auto !important;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    gap: 1.5rem !important;
    padding-bottom: 1rem;
}
.cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
.cr-slider-pdfs .cr-slider-pdfs__track > * {
    flex: 0 0 calc((100% - 3rem) / 3) !important;
    scroll-snap-align: start;
    min-width: 0;
    max-width: none !important;
}
@media (max-width: 900px) {
    .cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex-basis: calc((100% - 1.5rem) / 2) !important;
    }
}
@media (max-width: 600px) {
    .cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex-basis: 85% !important;
    }
}
.cr-slider-pdfs__card {
    max-width: none !important;
    width: 100%;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    padding: 1.5rem;
    text-align: center;
    border-radius: 4px;
    height: 100%;
    box-sizing: border-box;
}





/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */

/* ============================================================================
   D-140 (Ronda 2 â€” lote crÃ­tico, audit 29-ux-rondas/r02-lote-critico.md)
   Fixes consolidados:
   - Fix 1: logo PNG real (site-logo block) en lugar de wordmark inline
   - Fix 2: nav horizontal + social icons en header (estilo prod)
   - Fix 4: badge categorÃ­a sobre featured image en cr-grid-3col
   ============================================================================ */
/* stylelint-disable no-descending-specificity */

/* --- Fix 1: logo PNG dimensiones y aspect-ratio (CLS-safe). --- */
.cr-header__brand .custom-logo,
.cr-header__logo .custom-logo,
.cr-header__brand img {
    max-width: 280px;
    height: auto;
    /* Logo real es 2268Ã—281, aspect-ratio mantiene proporciÃ³n + previene CLS. */
    aspect-ratio: 2268 / 281;
    display: block;
}

/* --- Fix 2: layout horizontal del header (brand izq, nav+social der). --- */
.cr-header .cr-header__inner {
    display: flex !important;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
    gap: var(--wp--preset--spacing--40, 1.5rem);
    padding: var(--wp--preset--spacing--30, 1rem) var(--wp--preset--spacing--40, 1.5rem);
}

.cr-header .cr-header__brand {
    flex: 0 0 auto;
    line-height: 0;
}

.cr-header .cr-header__nav-wrap {
    flex: 1 1 auto;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: var(--wp--preset--spacing--40, 1.5rem);
}

/* --- Fix 2: nav horizontal en desktop con versalitas (estilo prod). --- */
@media (min-width: 901px) {
    .cr-header .cr-header__nav .wp-block-navigation__container,
    .cr-header .cr-header__nav ul {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        gap: var(--wp--preset--spacing--40, 1.5rem);
        list-style: none;
        margin: 0;
        padding: 0;
    }

    .cr-header .cr-header__nav a,
    .cr-header .cr-header__nav .wp-block-navigation-item__content {
        /* UX-R3 Fix#1: versalitas reales completas (smcp + c2sc + variant). */
        font-feature-settings: "smcp" 1, "c2sc" 1;
        -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
        font-variant-caps: all-small-caps;
        text-transform: uppercase;
        letter-spacing: 0.08em;
        font-size: var(--wp--preset--font-size--sm, 0.875rem);
        font-weight: 600;
        color: var(--wp--preset--color--text-strong, #000000);
        text-decoration: none;
        transition: color 0.2s ease;
    }

    .cr-header .cr-header__nav a:hover,
    .cr-header .cr-header__nav .wp-block-navigation-item__content:hover {
        color: var(--wp--preset--color--primary, #89100F);
    }
}

/* --- Fix 2: redes sociales en header â€” iguales que footer pero tema claro. --- */
.cr-header .cr-header__social {
    display: flex;
    gap: var(--wp--preset--spacing--30, 0.75rem);
    align-items: center;
    margin-left: var(--wp--preset--spacing--30, 0.75rem);
}

.cr-header .cr-header__social-link {
    color: var(--wp--preset--color--text-strong, #000000);
    opacity: 0.7;
    transition: opacity 0.3s ease, color 0.3s ease;
    display: inline-flex;
    align-items: center;
    line-height: 0;
    text-decoration: none;
}

.cr-header .cr-header__social-link:hover,
.cr-header .cr-header__social-link:focus-visible {
    opacity: 1;
    color: var(--wp--preset--color--primary, #89100F);
    outline: none;
}

.cr-header .cr-header__social-link:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 4px;
    border-radius: 2px;
}

.cr-header .cr-header__social svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

/* --- Fix 2: comportamiento responsive del header (mobile = stack). --- */
@media (max-width: 900px) {
    .cr-header .cr-header__nav-wrap {
        gap: var(--wp--preset--spacing--30, 0.75rem);
    }
    .cr-header .cr-header__social {
        margin-left: 0;
    }
}

@media (max-width: 600px) {
    .cr-header .cr-header__brand .custom-logo,
    .cr-header .cr-header__brand img {
        max-width: 200px;
    }
    .cr-header .cr-header__social {
        gap: 0.5rem;
    }
}

/* --- Fix 4: wrapper relativo del media + badge absolute en cr-grid-3col. --- */
.cr-grid-3col .cr-grid-3col__media-wrap {
    position: relative;
    margin: 0 0 var(--wp--preset--spacing--30, 1rem);
    /* Reset del layout constrained de WP para que el wrap no aÃ±ada margins. */
    --wp--style--root--padding-left: 0;
    --wp--style--root--padding-right: 0;
}

.cr-grid-3col .cr-grid-3col__media-wrap .wp-block-post-featured-image,
.cr-grid-3col .cr-grid-3col__image {
    margin: 0;
    display: block;
}

.cr-grid-3col .cr-grid-3col__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    padding: 4px 9px;
    /* Token xs (0.75rem) = consistencia con otros badges. */
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    /* UX-R3 Fix#1: versalitas reales completas (smcp + c2sc). */
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    font-weight: 700;
    border-radius: 2px;
    text-decoration: none;
    line-height: 1.3;
    /* Override del overflow:hidden + ellipsis de D-135 que aplica a este selector
       â€” aquÃ­ queremos badge visible completo sobre la imagen. */
    max-width: calc(100% - 24px);
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

.cr-grid-3col .cr-grid-3col__badge a {
    color: inherit;
    text-decoration: none;
}

.cr-grid-3col .cr-grid-3col__badge:empty {
    display: none;
}





/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */

/* ============================================================================
   UX-R3 (Ronda 3 â€” tipografÃ­a monumental + drop cap + 68ch lectura)
   Norte: Teopolis (serif display monumental, versalitas reales) + First Things
   (peso editorial visible) + Mere Orthodoxy (line-length 60-75 chars).
   ============================================================================ */
/* stylelint-disable no-descending-specificity */

/* --- UX-R3 Fix#3: max-width 68ch + leading editorial para body del single. --- */
.cr-single__content,
main.cr-single .wp-block-post-content,
.cr-single .cr-single__main-col .wp-block-post-content {
    max-width: 68ch;
    margin-inline: auto;
    /* Body ligeramente fluido: 16.8px mobile â†’ 18.4px desktop. */
    font-size: clamp(1.05rem, 1rem + 0.25vw, 1.15rem);
    line-height: 1.7;
    color: var(--wp--preset--color--text, #202020);
}

.cr-single__content p,
main.cr-single .wp-block-post-content > p {
    margin-bottom: 1.25em;
}

.cr-single__content h2,
main.cr-single .wp-block-post-content h2 {
    margin-top: 2.5em;
    margin-bottom: 0.75em;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.5rem, 1.25rem + 1vw, 2rem);
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.015em;
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-single__content h3,
main.cr-single .wp-block-post-content h3 {
    margin-top: 2em;
    margin-bottom: 0.6em;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.75vw, 1.5rem);
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: -0.01em;
}

/* --- UX-R3 Fix#2: drop cap editorial en primer pÃ¡rrafo del single.
   `:first-of-type` evita activarlo si el primer bloque es figure/quote/etc.
   color primary vinotinto + serif display (Bodoni Moda). text-shadow sutil
   con bg-soft para refinar contra fondo blanco sin halo. --- */
.cr-single__content > .wp-block-paragraph:first-of-type::first-letter,
main.cr-single .wp-block-post-content > p:first-of-type::first-letter {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: 5em;
    font-weight: 900;
    line-height: 0.85;
    float: left;
    margin: 0.05em 0.12em 0 0;
    color: var(--wp--preset--color--primary, #89100F);
    text-shadow: 0 2px 0 var(--wp--preset--color--bg-soft, #FCF7F7);
    /* OpenType "dlig" + "lnum" para Bodoni â€” figuras lining en drop cap. */
    font-feature-settings: "dlig" 1, "lnum" 1;
}

/* --- UX-R3 Fix#4: escalas fluid clamp() en titulares hero (mobile sostenible).
   Coordina con theme.json (4xl/5xl) pero blinda los selectores del theme. --- */
.cr-single__title,
.cr-single .wp-block-post-title.cr-single__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    /* 32px mobile â†’ 60px desktop. */
    font-size: clamp(2rem, 1.5rem + 2vw, 3.75rem);
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-grid-hero__title,
.cr-grid-hero .cr-grid-hero__title,
.cr-grid-hero__lead-col .cr-grid-hero__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    /* 28px mobile â†’ 52px desktop â€” sobreescribe el clamp anterior 2rem/4vw/3.25rem
       (D-132) que era mÃ¡s conservador. */
    font-size: clamp(1.75rem, 1.25rem + 2vw, 3.25rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.02em;
}

/* Cards (h3) â€” escala consistente: ~17.5px â†’ 21px. */
.cr-grid-3col__post-title,
.cr-grid-3col .cr-grid-3col__post-title,
.cr-grid-hero__rail-title,
.cr-grid-hero__rail .cr-grid-hero__rail-title,
.cr-grid-2col .wp-block-post-title,
.cr-grid-4col .wp-block-post-title,
.cr-grid-list .wp-block-post-title,
.cr-grid-magazine .wp-block-post-title,
.cr-archive .wp-block-post-title {
    font-size: clamp(1.1rem, 1rem + 0.4vw, 1.3rem);
    line-height: 1.25;
    letter-spacing: -0.005em;
}

/* --- UX-R3 Fix#5: spacing tipogrÃ¡fico â€” titulares Bodoni apretados, body cÃ³modo. --- */
h1, h2, h3,
.cr-single__title,
.cr-grid-hero__title,
.cr-grid-hero__rail-title {
    /* letter-spacing mÃ¡s apretado que el default para Bodoni â€” sensaciÃ³n editorial. */
}

/* H1 line-height bien apretado (cuando ocupa varias lÃ­neas). */
.cr-single__title { line-height: 1.05; }
.cr-grid-hero__title { line-height: 1.05; }

/* Print-safe â€” drop cap se ve raro en print, neutralizar. */
@media print {
    .cr-single__content > .wp-block-paragraph:first-of-type::first-letter,
    main.cr-single .wp-block-post-content > p:first-of-type::first-letter {
        font-size: inherit;
        float: none;
        margin: 0;
        color: inherit;
        text-shadow: none;
    }
}

/* Mobile (â‰¤600px): drop cap mÃ¡s modesto para no canibalizar el primer pÃ¡rrafo. */
@media (max-width: 600px) {
    .cr-single__content > .wp-block-paragraph:first-of-type::first-letter,
    main.cr-single .wp-block-post-content > p:first-of-type::first-letter {
        font-size: 4em;
        margin: 0.05em 0.1em 0 0;
    }
}

/* ============================================================
 * UX-R4 â€” Hero oscuro dramÃ¡tico (espejo prod catolicismoreformado.com)
 * Lead full-width con imagen + overlay 30â†’70%, tÃ­tulo blanco centrado,
 * avatar circular + autor versalitas "Por X". Sticky-only en wp:query.
 * ============================================================ */
.cr-grid-hero__lead-wrap { margin: 0 0 4rem; }
.cr-grid-hero__lead-wrap .wp-block-post-template { margin: 0; padding: 0; list-style: none; }
.cr-grid-hero__lead-wrap .wp-block-post-template > li { margin: 0; list-style: none; }

.cr-grid-hero__lead-card {
    position: relative;
    width: 100%;
    max-width: 1400px;
    margin: 0 auto;
    overflow: hidden;
    border-radius: 4px;
    isolation: isolate;
}
.cr-grid-hero__lead-image,
.cr-grid-hero__lead-card .cr-grid-hero__lead-image {
    margin: 0 !important;
    padding: 0;
}
.cr-grid-hero__lead-card .cr-grid-hero__lead-image img,
.cr-grid-hero__lead-card .wp-block-post-featured-image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
    aspect-ratio: 21 / 9;
    filter: brightness(0.55);
    transition: filter 600ms ease;
}
.cr-grid-hero__lead-card:hover .cr-grid-hero__lead-image img,
.cr-grid-hero__lead-card:hover .wp-block-post-featured-image img {
    filter: brightness(0.7);
}
.cr-grid-hero__lead-card::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.7) 100%);
    pointer-events: none;
    z-index: 1;
}
.cr-grid-hero__lead-overlay {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: flex !important;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 3rem 1.5rem;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    max-width: 900px;
    margin-inline: auto;
}
.cr-grid-hero__lead-badge {
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    padding: 6px 14px;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.1em;
    font-size: 0.85rem;
    font-weight: 700;
    border-radius: 2px;
    margin-bottom: 1.5rem;
    text-decoration: none;
    display: inline-block;
    line-height: 1.2;
}
.cr-grid-hero__lead-badge a,
.cr-grid-hero__lead-badge a:link,
.cr-grid-hero__lead-badge a:visited {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    text-decoration: none;
    background: transparent;
}
.cr-grid-hero__lead-title,
.cr-grid-hero.cr-grid-hero .cr-grid-hero__lead-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.75rem, 1.25rem + 2.5vw, 3.75rem);
    font-weight: 800;
    line-height: 1.05;
    letter-spacing: -0.02em;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    margin: 0 0 2rem;
    text-shadow: 0 2px 8px rgba(0,0,0,0.3);
    max-width: 18ch;
}
.cr-grid-hero__lead-title a,
.cr-grid-hero__lead-title a:link,
.cr-grid-hero__lead-title a:visited,
.cr-grid-hero.cr-grid-hero .cr-grid-hero__lead-title a {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    text-decoration: none;
    background: transparent;
}
.cr-grid-hero__lead-meta {
    display: flex;
    gap: 0.75rem;
    align-items: center;
    color: rgba(255,255,255,0.85);
}
.cr-grid-hero__lead-avatar img,
.cr-grid-hero__lead-avatar .avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    border: 2px solid rgba(255,255,255,0.4);
    display: block;
}
.cr-grid-hero__lead-author {
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    margin: 0;
}
.cr-grid-hero__lead-author a,
.cr-grid-hero__lead-author a:link,
.cr-grid-hero__lead-author a:visited {
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    text-decoration: none;
}
.cr-grid-hero__lead-author::before {
    content: "Por ";
    opacity: 0.7;
    font-variant: normal;
    font-feature-settings: normal;
    text-transform: none;
    letter-spacing: 0;
    font-size: 0.85rem;
}

@media (max-width: 600px) {
    .cr-grid-hero__lead-card .cr-grid-hero__lead-image img,
    .cr-grid-hero__lead-card .wp-block-post-featured-image img {
        aspect-ratio: 4 / 5;
        filter: brightness(0.45);
    }
    .cr-grid-hero__lead-overlay { padding: 2rem 1rem; }
    .cr-grid-hero__lead-title,
    .cr-grid-hero.cr-grid-hero .cr-grid-hero__lead-title {
        font-size: clamp(1.5rem, 1.25rem + 2vw, 2rem);
        margin-bottom: 1.5rem;
    }
    .cr-grid-hero__lead-avatar img { width: 40px; height: 40px; }
}

@media (prefers-reduced-motion: reduce) {
    .cr-grid-hero__lead-card .cr-grid-hero__lead-image img,
    .cr-grid-hero__lead-card .wp-block-post-featured-image img {
        transition: none;
    }
    .cr-grid-hero__lead-card:hover .cr-grid-hero__lead-image img,
    .cr-grid-hero__lead-card:hover .wp-block-post-featured-image img {
        filter: brightness(0.55);
    }
}





/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */

/* ============================================================
 * UX-R5 â€” Sidebar editorial sticky + breadcrumb + eyebrow single
 * (audit 29-ux-rondas/r05-sidebar-breadcrumb.md)
 * Norte: Teopolis Article-Lead (eyebrow + meta horizontal) +
 * White Horse Inn (sidebar promocional sticky + podcast).
 * ============================================================ */
/* stylelint-disable no-descending-specificity */

/* --- UX-R5 Fix 3: breadcrumb editorial (versalitas + rule debajo) --- */
.cr-breadcrumb {
    padding: 1rem 0;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.8rem;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
}

.cr-breadcrumb:empty,
.cr-breadcrumb .wp-block-shortcode:empty {
    /* Si Rank Math no estÃ¡ activo o breadcrumbs estÃ¡ off, el shortcode
       imprime vacÃ­o â€” colapsar el wrapper para no aÃ±adir margen muerto. */
    display: none;
}

.cr-breadcrumb .rank-math-breadcrumb,
.cr-breadcrumb .rank-math-breadcrumb p {
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    margin: 0;
}

.cr-breadcrumb__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
    list-style: none;
    margin: 0;
    padding: 0;
}

.cr-breadcrumb__item {
    display: inline-flex;
    align-items: center;
}

.cr-breadcrumb__current {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-breadcrumb a {
    color: var(--wp--preset--color--primary, #89100F);
    text-decoration: none;
    transition: opacity 0.15s ease;
}

.cr-breadcrumb a:hover,
.cr-breadcrumb a:focus-visible {
    text-decoration: underline;
    outline: none;
}

.cr-breadcrumb a:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
}

.cr-breadcrumb .separator {
    margin: 0 0.5rem;
    opacity: 0.5;
    color: var(--wp--preset--color--muted, #888888);
}

/* --- UX-R5 Fix 4: eyebrow + meta horizontal en hero del single
   (estilo Teopolis Article-Lead). Refina el header del cr-single. --- */
.cr-single__header {
    max-width: 720px;
    margin: 0 auto 3rem;
    padding-top: 2rem;
}

.cr-single__category,
.cr-single .cr-single__category {
    /* UX-R5: eyebrow vinotinto en versalitas, NO badge sÃ³lido.
       Sobreescribe el badge pill de D-121 (cr-single__category share). */
    display: inline-block;
    background: transparent !important;
    color: var(--wp--preset--color--primary, #89100F) !important;
    padding: 0;
    margin: 0 0 1.5rem;
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.12em;
    font-size: 0.85rem;
    font-weight: 800;
    text-transform: uppercase;
    text-shadow: none;
    border-radius: 0;
    line-height: 1.2;
    max-width: none;
}

.cr-single__category a,
.cr-single .cr-single__category a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.2s ease;
}

.cr-single__category a:hover,
.cr-single .cr-single__category a:focus-visible {
    border-bottom-color: var(--wp--preset--color--primary, #89100F);
    outline: none;
}

.cr-single__title,
.cr-single .cr-single__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2rem, 1.5rem + 2vw, 3.75rem);
    font-weight: 900;
    line-height: 1.05;
    letter-spacing: -0.02em;
    margin: 0 0 2rem;
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-single__meta {
    gap: 1rem;
    margin-bottom: 3rem;
    align-items: center;
}

.cr-single__author-avatar img,
.cr-single .cr-single__author-avatar img {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: block;
}

.cr-single__author-name,
.cr-single .cr-single__author-name {
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--wp--preset--color--primary, #89100F);
    text-transform: uppercase;
}

.cr-single__author-name a,
.cr-single .cr-single__author-name a {
    color: inherit;
    text-decoration: none;
}

.cr-single__author-name a:hover {
    text-decoration: underline;
}

.cr-single__date-row {
    gap: 1rem;
    font-size: 0.85rem;
    color: var(--wp--preset--color--muted-strong, #666666);
    align-items: center;
}

.cr-single__date-row > * + * {
    position: relative;
    padding-left: 1rem;
}

.cr-single__date-row > * + *::before {
    content: "Â·";
    position: absolute;
    left: 0;
    opacity: 0.5;
}

/* --- UX-R5 Fix 4: featured image full-width despuÃ©s del header.
   El header constrained a 720px deja respirar el tÃ­tulo, luego el
   hero ocupa el ancho de la columna (66.66% del wide). --- */
.cr-single__hero,
.cr-single .cr-single__hero {
    max-width: 100%;
    margin: 0 auto 3rem;
}

.cr-single__hero img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 4px;
}

/* --- UX-R5 Fix 1+2: sidebar editorial sticky + estilos de widgets.
   Mantiene el sticky de UX-R1 pero refuerza tipografÃ­a y espaciado. --- */
.cr-sidebar {
    gap: 2.5rem;
    padding-left: 0;
}

@media (min-width: 901px) {
    .cr-sidebar {
        /* Refuerza el sticky con un offset cÃ³modo respecto al header. */
        padding-top: 0.5rem;
    }
}

.cr-sidebar__recommend,
.cr-sidebar__podcast {
    padding: 1.5rem;
    background: var(--wp--preset--color--bg-soft, #FCF7F7);
    border: 1px solid var(--wp--preset--color--rule, #E8EBEE);
    border-radius: 4px;
}

.cr-sidebar__eyebrow {
    font-family: var(--wp--preset--font-family--body, system-ui, sans-serif);
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.1em;
    font-size: 0.8rem;
    font-weight: 800;
    color: var(--wp--preset--color--primary, #89100F);
    text-transform: uppercase;
    margin: 0 0 0.5rem;
}

.cr-sidebar__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: 1.35rem;
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.01em;
    margin: 0 0 1rem;
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-sidebar__cover {
    margin: 0 0 1rem;
}

.cr-sidebar__cover img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 2px;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.12);
}

.cr-sidebar__description {
    font-size: 0.95rem;
    line-height: 1.55;
    color: var(--wp--preset--color--text, #202020);
    margin: 0 0 1.25rem;
}

.cr-sidebar__cta .wp-block-button__link {
    width: 100%;
    text-align: center;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 0.75rem 1.5rem;
}

.cr-sidebar__podcast iframe {
    display: block;
    margin: 0 0 1rem;
    border: 0;
    width: 100%;
}

.cr-sidebar__podcast-fallback {
    position: relative;
    overflow: hidden;
    margin: 0 0 1rem;
    padding: 1.25rem;
    border: 1px solid rgba(137, 16, 15, 0.14);
    border-radius: 2px;
    background:
        radial-gradient(circle at 100% 0%, rgba(137, 16, 15, 0.14), transparent 42%),
        linear-gradient(135deg, #fff 0%, var(--wp--preset--color--bg-soft, #FCF7F7) 100%);
}

.cr-sidebar__podcast-kicker {
    margin: 0 0 0.5rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: 0.75rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-sidebar__podcast-name {
    margin: 0 0 1rem;
    max-width: 13ch;
    color: var(--wp--preset--color--text-strong, #111111);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.1rem + 1vw, 1.8rem);
    font-weight: 900;
    line-height: 1;
    letter-spacing: -0.035em;
}

.cr-sidebar__podcast-button {
    display: inline-flex;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    padding: 0.7rem 1rem;
    border-radius: 999px;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-decoration: none;
    text-transform: uppercase;
    transition: transform 240ms var(--cr-motion-premium), background 240ms var(--cr-motion-premium);
}

.cr-sidebar__podcast-button:hover,
.cr-sidebar__podcast-button:focus-visible {
    background: #650908;
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    transform: translateY(-1px);
}

.cr-sidebar__podcast-embed {
    margin: 0 0 1rem;
    font-size: 0.85rem;
}

.cr-sidebar__podcast-embed summary {
    min-height: 44px;
    cursor: pointer;
    color: var(--wp--preset--color--primary, #89100F);
    font-weight: 700;
}

.cr-sidebar__podcast-embed iframe {
    margin-top: 0.75rem;
}

.cr-sidebar__platforms {
    font-size: 0.85rem;
    line-height: 1.6;
    margin: 0;
    color: var(--wp--preset--color--text, #202020);
}

.cr-sidebar__platforms strong {
    font-feature-settings: "smcp" 1, "c2sc" 1;
    -webkit-font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.8rem;
    font-weight: 800;
    color: var(--wp--preset--color--primary, #89100F);
    display: block;
    margin-bottom: 0.35rem;
}

.cr-sidebar__platforms a {
    color: var(--wp--preset--color--primary, #89100F);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: border-color 0.15s ease;
}

.cr-sidebar__platforms a:hover,
.cr-sidebar__platforms a:focus-visible {
    border-bottom-color: var(--wp--preset--color--primary, #89100F);
    outline: none;
}

.cr-sidebar__platforms a:focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 2px;
}

/* Mobile: sidebar fuera del flow sticky, padding reducido. */
@media (max-width: 900px) {
    .cr-single .cr-sidebar {
        margin-top: 2rem;
    }
    .cr-sidebar__recommend,
    .cr-sidebar__podcast {
        padding: 1.25rem;
    }
}

@media (max-width: 600px) {
    .cr-single__header {
        padding-top: 1rem;
        margin-bottom: 2rem;
    }
    .cr-single__meta {
        gap: 0.75rem;
        margin-bottom: 2rem;
    }
    .cr-single__date-row {
        gap: 0.5rem;
        font-size: 0.8rem;
    }
    .cr-breadcrumb {
        font-size: 0.75rem;
        padding: 0.75rem 0;
    }
}





/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */

/* ============================================================
 * RONDA 6 (UX) â€” Secciones temÃ¡ticas del home (replica prod)
 * ============================================================
 * Patterns: cr-section-vivir-la-fe, cr-section-mas-populares,
 *           cr-section-anglicanismo
 * Las 3 secciones comparten estructura .cr-section / .cr-section__*
 * - Card layout horizontal (image 35% + body 65%)
 * - Ranking con CSS counter (sin necesidad de plugin de views)
 * - Variantes grid 2col y 3col responsivas
 * ============================================================ */

/* stylelint-disable no-descending-specificity */

/* --- SecciÃ³n base --- */
.cr-section {
    padding: 5rem 0;
}
.cr-section.has-bg-soft-background-color {
    padding-left: var(--wp--preset--spacing--40, 1.5rem);
    padding-right: var(--wp--preset--spacing--40, 1.5rem);
}
.cr-section__header {
    margin-bottom: 3rem;
    align-items: baseline !important;
}
.cr-section__title {
    font-family: var(--wp--preset--font-family--display);
    font-size: clamp(1.75rem, 1.5rem + 1.5vw, 2.75rem);
    font-weight: 900;
    letter-spacing: -0.015em;
    color: var(--wp--preset--color--primary);
    margin: 0;
    line-height: 1.1;
}
.cr-section__link {
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.08em;
    font-size: 0.85rem;
    font-weight: 700;
    margin: 0;
}
.cr-section__link a {
    color: var(--wp--preset--color--primary);
    text-decoration: none;
}
.cr-section__link a:hover,
.cr-section__link a:focus-visible {
    text-decoration: underline;
}
.cr-section__empty {
    color: var(--wp--preset--color--muted-strong);
    font-style: italic;
    text-align: center;
    padding: 2rem 0;
}

/* --- Grids 2col / 3col --- */
.cr-section__grid--2col {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
}
.cr-section__grid--3col {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}
@media (max-width: 900px) {
    .cr-section__grid--2col { grid-template-columns: 1fr; }
    .cr-section__grid--3col { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .cr-section__grid--3col { grid-template-columns: 1fr; }
}

/* --- Cards (horizontal image + body) --- */
.cr-section__card {
    gap: 1rem !important;
}
.cr-section__card-image {
    flex: 0 0 35%;
    margin: 0;
}
.cr-section__card-image img {
    aspect-ratio: 3 / 4;
    object-fit: cover;
    width: 100%;
    height: auto;
    display: block;
}
.cr-section__card-body {
    flex: 1 1 auto;
    min-width: 0;
}
.cr-section__card-badge {
    background: var(--wp--preset--color--primary);
    color: #FFFFFF;
    padding: 3px 8px;
    font-size: 0.7rem;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.06em;
    font-weight: 700;
    border-radius: 2px;
    display: inline-block;
    margin-bottom: 0.5rem;
    line-height: 1.3;
}
.cr-section__card-badge:empty {
    display: none;
}
.cr-section__card-badge a {
    color: inherit;
    text-decoration: none;
}
.cr-section__card-title {
    font-family: var(--wp--preset--font-family--display);
    font-size: clamp(1.1rem, 1rem + 0.4vw, 1.35rem);
    line-height: 1.25;
    margin: 0 0 0.5rem;
    color: var(--wp--preset--color--text-strong);
    font-weight: 700;
}
.cr-section__card-title a {
    color: inherit;
    text-decoration: none;
}
.cr-section__card-title a:hover,
.cr-section__card-title a:focus-visible {
    color: var(--wp--preset--color--primary);
}
.cr-section__card-meta {
    gap: 0.75rem !important;
    font-size: 0.8rem;
    color: var(--wp--preset--color--muted-strong);
    flex-wrap: wrap;
}
.cr-section__card-author {
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.06em;
    font-weight: 700;
    color: var(--wp--preset--color--primary);
}
.cr-section__card-date {
    color: var(--wp--preset--color--muted-strong);
}

/* --- Ranking "MÃ¡s populares" --- */
.cr-section__ranking {
    counter-reset: rank;
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 0;
}
.cr-section__ranking-item {
    counter-increment: rank;
    padding: 1.25rem 0;
    border-top: 1px solid var(--wp--preset--color--rule, #e4ddd1);
    gap: 1.25rem !important;
    align-items: center;
}
.cr-section__ranking-item:last-child {
    border-bottom: 1px solid var(--wp--preset--color--rule, #e4ddd1);
}
.cr-section__ranking-item::before {
    content: counter(rank);
    font-family: var(--wp--preset--font-family--display);
    font-size: clamp(2.5rem, 1.5rem + 3vw, 4rem);
    font-weight: 900;
    color: var(--wp--preset--color--primary);
    line-height: 1;
    min-width: 2ch;
    text-align: right;
    opacity: 0.3;
    flex: 0 0 auto;
    letter-spacing: -0.04em;
}
.cr-section__ranking-body {
    flex: 1 1 auto;
    min-width: 0;
}
.cr-section__ranking-title {
    font-family: var(--wp--preset--font-family--display);
    font-size: clamp(1rem, 0.95rem + 0.3vw, 1.25rem);
    line-height: 1.3;
    margin: 0 0 0.35rem;
    color: var(--wp--preset--color--text-strong);
    font-weight: 700;
}
.cr-section__ranking-title a {
    color: inherit;
    text-decoration: none;
}
.cr-section__ranking-title a:hover,
.cr-section__ranking-title a:focus-visible {
    color: var(--wp--preset--color--primary);
}
.cr-section__ranking-meta {
    gap: 0.75rem !important;
    font-size: 0.8rem;
    color: var(--wp--preset--color--muted-strong);
    flex-wrap: wrap;
}
.cr-section__ranking-author {
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
    letter-spacing: 0.06em;
    font-weight: 700;
    color: var(--wp--preset--color--primary);
}
.cr-section__ranking-date {
    color: var(--wp--preset--color--muted-strong);
}

/* --- Responsive secciones --- */
@media (max-width: 600px) {
    .cr-section { padding: 3rem 0; }
    .cr-section.has-bg-soft-background-color { padding-left: 1rem; padding-right: 1rem; }
    .cr-section__header { margin-bottom: 2rem; }
    .cr-section__card { flex-direction: column !important; gap: 0.75rem !important; }
    .cr-section__card-image { flex: 1 1 auto; }
    .cr-section__ranking-item { gap: 0.75rem !important; padding: 1rem 0; }
    .cr-section__ranking-item::before { font-size: 2.25rem; min-width: 1.5ch; }
}





/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */



/* ============================================================
 * STAGE 13-24 visual baseline repair ? editorial width, logo,
 * mobile title/search overflow. Screenshot-driven from Stage 12.
 * ============================================================ */
/* stylelint-disable no-descending-specificity */

:root {
    --cr-visual-wide: min(1180px, calc(100vw - 48px));
    --cr-visual-reading: min(720px, calc(100vw - 32px));
    --cr-motion-premium: cubic-bezier(0.32, 0.72, 0, 1);
}

/* Header / logo: make brand visible and keep controls tappable. */
.cr-header {
    position: sticky;
    top: 0;
    z-index: 20;
    width: 100%;
    background: transparent;
    border-bottom: 1px solid rgba(137, 16, 15, 0.08);
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    overflow: visible;
}

.cr-header::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: saturate(140%) blur(10px);
    -webkit-backdrop-filter: saturate(140%) blur(10px);
}

.cr-header .cr-header__inner {
    position: relative;
    z-index: 1;
    width: var(--cr-visual-wide);
    max-width: var(--cr-visual-wide);
    margin-inline: auto;
    padding: clamp(0.7rem, 1.6vw, 1.15rem) 0;
    gap: clamp(0.75rem, 2vw, 2rem);
}

.cr-header__brand {
    flex: 0 1 auto;
    min-width: 0;
}

.cr-header .cr-header__logo,
.cr-header .wp-block-site-logo {
    display: block;
    line-height: 0;
    margin: 0;
}

.cr-header .cr-header__logo img,
.cr-header .cr-header__logo a,
.cr-header .cr-header__logo .custom-logo,
.cr-header .wp-block-site-logo img,
.cr-header .custom-logo {
    width: clamp(180px, 22vw, 320px);
    max-width: 100%;
    max-height: none;
    height: auto;
    aspect-ratio: 553 / 74;
    object-fit: contain;
    display: block;
}

.cr-header .cr-header__logo a {
    width: clamp(180px, 22vw, 320px);
}

.cr-header__nav-wrap {
    margin-left: auto;
    gap: clamp(0.35rem, 1.5vw, 1rem);
}

.cr-header__social {
    display: inline-flex;
    align-items: center;
    gap: 0.15rem;
}

.cr-header__social-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
    color: var(--wp--preset--color--text-strong, #111111);
    opacity: 0.72;
    transition: opacity 240ms var(--cr-motion-premium), transform 240ms var(--cr-motion-premium);
}

.cr-header__social-link:hover,
.cr-header__social-link:focus-visible {
    opacity: 1;
    transform: translateY(-1px);
}

/* Escape overly narrow WP constrained defaults on key editorial templates. */
.cr-home.wp-block-group,
.cr-single.wp-block-group,
.cr-search.wp-block-group,
.cr-archive.wp-block-group,
.cr-404.wp-block-group {
    width: 100%;
    max-width: none;
}

.cr-home > :where(.wp-block-group, .wp-block-query, .wp-block-columns, .cr-section, .cr-grid-hero, .cr-slider-pdfs, .cr-home__post-area),
.cr-home > .cr-rule,
.cr-single > :where(.cr-breadcrumb, .cr-single__layout),
.cr-search > :where(.cr-search__header, .wp-block-query),
.cr-archive > :where(.wp-block-group, .wp-block-query, .wp-block-columns, .cr-archive__columns),
.cr-404 > :where(.cr-404__hero, .cr-404__recent-heading, .cr-404__recent) {
    width: var(--cr-visual-wide);
    max-width: var(--cr-visual-wide);
    margin-left: auto;
    margin-right: auto;
}

#wp--skip-link--target {
    scroll-margin-top: calc(var(--cr-header-height, 72px) + 1rem);
}

:where(a, button, summary, .wp-block-button__link):focus-visible {
    outline: 2px solid var(--wp--preset--color--primary, #89100F);
    outline-offset: 3px;
    border-radius: 2px;
}

.cr-archive .wp-block-post-template {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: clamp(1.5rem, 3vw, 2.25rem) !important;
}

.cr-archive .wp-block-post {
    position: relative;
}

.cr-single .cr-single__layout {
    align-items: flex-start;
    column-gap: clamp(2rem, 5vw, 4.5rem) !important;
}

.cr-single .cr-single__main-col {
    flex-basis: min(68%, 760px) !important;
}

.cr-single .cr-single__sidebar-col {
    flex-basis: min(32%, 340px) !important;
}

.cr-single__header,
.cr-single .cr-single__header,
.cr-single__content,
.cr-single .cr-single__content {
    max-width: var(--cr-visual-reading);
}

.cr-single__title,
.cr-single .cr-single__title {
    text-wrap: balance;
    overflow-wrap: anywhere;
}

.cr-single__content {
    font-size: clamp(1.05rem, 0.98rem + 0.35vw, 1.18rem);
    line-height: 1.78;
}

/* Search form overflow fix + premium input rhythm. */
.cr-search__header {
    padding-block: clamp(2rem, 5vw, 4rem) 1.5rem;
}

.cr-search__form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: stretch;
    width: min(100%, 640px);
    max-width: 100%;
    gap: 0.5rem;
}

.cr-search__form .wp-block-search__inside-wrapper {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    width: 100%;
    max-width: 100%;
    gap: 0.5rem;
}

.cr-search__form input[type="search"] {
    min-width: 0;
    width: 100%;
}

@media (min-width: 901px) {
    .cr-home .cr-grid-hero__featured .wp-block-post-featured-image {
        max-width: none;
    }

    .cr-home .cr-grid-hero__lead-card {
        max-width: var(--cr-visual-wide);
    }
}

.cr-grid-hero__rail-item {
    position: relative;
}

.cr-grid-hero__lead-image,
.cr-grid-hero__lead-card .cr-grid-hero__lead-image {
    aspect-ratio: auto !important;
    min-height: clamp(340px, 32vw, 520px);
}

.cr-grid-hero__lead-card .wp-block-post-featured-image img,
.cr-grid-hero__lead-card .cr-grid-hero__lead-image img {
    min-height: clamp(340px, 32vw, 520px);
    height: 100% !important;
    object-fit: cover;
}

.cr-grid-hero__lead-overlay {
    max-width: min(860px, calc(100% - 32px));
}

.cr-grid-hero__lead-badge {
    margin-bottom: clamp(0.8rem, 2vw, 1.4rem);
}

@media (max-width: 900px) {
    :root {
        --cr-visual-wide: min(100% - 32px, 820px);
    }

    .cr-header .cr-header__inner {
        width: min(100% - 24px, 820px);
    }

    /* Stage 14: el core/navigation abría, pero el modal quedaba con alto de
       contenido (~62px) en mobile. Fijamos un overlay real 100dvh, con
       cierre visible y enlaces editoriales grandes/tocables. */
    .cr-header .cr-header__nav .wp-block-navigation__responsive-container.is-menu-open {
        position: fixed;
        inset: 0;
        width: 100vw;
        height: 100dvh;
        min-height: 100vh;
        box-sizing: border-box;
        padding: clamp(1rem, 4vw, 1.5rem);
        background:
            radial-gradient(circle at 20% 0%, rgba(137, 16, 15, 0.1), transparent 34%),
            rgba(255, 255, 255, 0.98);
        border-left: 1px solid rgba(137, 16, 15, 0.12);
        flex-direction: column !important;
        overflow: auto;
    }

    .cr-header .cr-header__nav .wp-block-navigation__responsive-container-close {
        top: clamp(0.8rem, 4vw, 1.25rem) !important;
        right: clamp(0.8rem, 4vw, 1.25rem) !important;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        min-width: 44px;
        min-height: 44px;
        border: 1px solid rgba(137, 16, 15, 0.16);
        border-radius: 999px;
        background: rgba(137, 16, 15, 0.06);
        color: var(--wp--preset--color--text-strong, #111111);
    }

    .cr-header .cr-header__nav .wp-block-navigation__responsive-container-content {
        width: 100%;
        min-height: calc(100dvh - 3rem);
        padding-top: clamp(4.75rem, 16vh, 7rem);
        align-items: flex-start;
        justify-content: flex-start;
    }

    .cr-header .cr-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation__container {
        width: 100%;
        gap: clamp(0.8rem, 3vw, 1.25rem);
        align-items: flex-start;
    }

    .cr-header .cr-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content {
        display: inline-flex;
        min-height: 44px;
        align-items: center;
        font-family: var(--wp--preset--font-family--display, Georgia, serif);
        font-size: clamp(2rem, 12vw, 4rem);
        line-height: 0.95;
        font-weight: 900;
        letter-spacing: -0.04em;
        color: var(--wp--preset--color--text-strong, #111111);
    }

    .cr-single .cr-single__main-col,
    .cr-single .cr-single__sidebar-col {
        flex-basis: 100% !important;
    }
}

@media (max-width: 600px) {
    :root {
        --cr-visual-wide: calc(100vw - 24px);
        --cr-visual-reading: calc(100vw - 24px);
    }

    .cr-header .cr-header__inner {
        width: calc(100vw - 20px);
        gap: 0.25rem;
        padding-block: 0.55rem;
    }

    .cr-header .cr-header__logo img,
    .cr-header .cr-header__logo .custom-logo,
    .cr-header .wp-block-site-logo img,
    .cr-header .custom-logo {
        width: clamp(168px, 50vw, 230px);
    }

    .cr-header__social-link {
        min-width: 44px;
        min-height: 44px;
    }

    .cr-header__social-link svg {
        width: 16px;
        height: 16px;
    }

    .cr-single .cr-single__title {
        font-size: clamp(2.05rem, 1.52rem + 7.2vw, 3.15rem);
        line-height: 0.98;
        letter-spacing: -0.035em;
        margin-bottom: 1.35rem;
    }

    .cr-single__header,
    .cr-single .cr-single__header {
        padding-top: 1.25rem;
        margin-bottom: 1.75rem;
    }

    .cr-single__meta {
        margin-bottom: 1.75rem;
    }

    .cr-grid-hero__lead-card .wp-block-post-featured-image img,
    .cr-grid-hero__lead-card .cr-grid-hero__lead-image img {
        min-height: clamp(280px, 78vw, 360px);
    }

    .cr-grid-hero__lead-image,
    .cr-grid-hero__lead-card .cr-grid-hero__lead-image {
        min-height: clamp(280px, 78vw, 360px);
    }

    .cr-grid-hero__lead-overlay {
        padding: 1.35rem 0.85rem;
        justify-content: center;
    }

    .cr-grid-hero__lead-badge {
        margin-bottom: 0.65rem;
        font-size: 0.72rem;
    }

    .cr-grid-hero__lead-title,
    .cr-grid-hero.cr-grid-hero .cr-grid-hero__lead-title {
        font-size: clamp(1.55rem, 1.05rem + 6.2vw, 2.35rem);
        line-height: 1;
        margin-bottom: 1rem;
        max-width: 12ch;
    }

    .cr-search__form,
    .cr-search__form .wp-block-search__inside-wrapper {
        grid-template-columns: 1fr;
        width: 100%;
        max-width: 100%;
    }

    .cr-search__form button,
    .cr-search__form .wp-block-search__button {
        width: 100%;
        min-height: 44px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-header__social-link {
        transition: none;
    }

    .cr-header__social-link:hover,
    .cr-header__social-link:focus-visible {
        transform: none;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-slider-pdfs__card,
    .cr-slider-pdfs__card img,
    .cr-slider-pdfs__cta .wp-block-button__link,
    .cr-podcast-cta__button,
    .cr-sidebar__podcast-button,
    .cr-grid-hero__lead-card img {
        transition: none !important;
        transform: none !important;
    }

    .cr-slider-pdfs__track,
    .cr-slider .cr-slider__track {
        scroll-behavior: auto !important;
    }
}

/* ============================================================
 * UXR12 — simetría editorial, sidebars correctos y recursos premium.
 * ============================================================ */

html,
body {
    max-width: 100%;
    overflow-x: clip;
}

@supports not (overflow-x: clip) {
    html,
    body {
        overflow-x: hidden;
    }
}

.cr-home > :where(.wp-block-columns, .cr-home__post-area) {
    width: var(--cr-visual-wide);
    max-width: var(--cr-visual-wide);
    margin-left: auto;
    margin-right: auto;
}

.cr-home__post-area {
    align-items: flex-start;
    gap: clamp(1.5rem, 4vw, 3rem) !important;
    margin-block: clamp(2rem, 5vw, 4rem);
}

.cr-home__post-main,
.cr-home__sidebar-col,
.cr-single__main-col,
.cr-single__sidebar-col,
.cr-archive__main,
.cr-archive__aside {
    min-width: 0;
}

@media (min-width: 901px) {
    .cr-home__sidebar-col,
    .cr-single .cr-single__sidebar-col,
    .cr-archive .cr-archive__aside {
        position: sticky;
        top: calc(var(--cr-header-height, 72px) + 1.25rem);
        align-self: flex-start;
    }

    .cr-home__post-area .cr-grid-3col .wp-block-post-template {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 900px) {
    .cr-home__post-area,
    .cr-archive__columns {
        flex-direction: column;
    }

    .cr-home__post-main,
    .cr-home__sidebar-col,
    .cr-archive__main,
    .cr-archive__aside {
        flex-basis: 100% !important;
        width: 100% !important;
    }
}

@media (max-width: 600px) {
    .cr-header .cr-header__inner {
        width: min(100%, calc(100vw - 24px));
        max-width: calc(100vw - 24px);
        gap: 0.35rem;
    }

    .cr-header .cr-header__logo img,
    .cr-header .cr-header__logo .custom-logo,
    .cr-header .cr-header__logo a {
        width: clamp(150px, 42vw, 178px);
    }

    .cr-header__nav-wrap {
        gap: 0.15rem;
    }

    .cr-header__social {
        gap: 0;
    }
}

/* Categorías arriba del artículo, no centradas en el plano visual. */
.cr-grid-hero__lead-card {
    position: relative;
}

.cr-grid-hero__lead-overlay {
    position: absolute;
    inset: 0;
}

.cr-grid-hero__lead-badge {
    position: absolute;
    top: clamp(1rem, 2vw, 2rem);
    left: 50%;
    z-index: 4;
    transform: translateX(-50%);
    margin: 0;
}

.cr-grid-hero__badge,
.cr-grid-3col .cr-grid-3col__badge,
.cr-archive__badge,
.cr-single__related-badge {
    top: 10px;
    left: 10px;
}

.cr-grid-3col .wp-block-post-template > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-grid-3col .wp-block-post-title {
    display: -webkit-box;
    min-height: 3.75em;
    margin-block: 0.95rem 0.65rem;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-grid-3col .cr-card__meta,
.cr-archive__item-meta,
.cr-sidebar-more__meta {
    margin-top: auto;
}

.cr-grid-3col .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-single__hero img,
.cr-sidebar-more__image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.cr-single__hero,
.cr-single .cr-single__hero {
    aspect-ratio: 900 / 537;
    max-width: 900px;
    overflow: hidden;
}

/* Secciones con fondo y cards simétricas, inspiradas en el layout editorial de referencia. */
.cr-section {
    background: var(--wp--preset--color--bg-soft, #F6F7F8);
}

.cr-section__grid--2col,
.cr-section__grid--3col {
    align-items: stretch;
}

.cr-section__grid--2col > li,
.cr-section__grid--3col > li {
    min-width: 0;
    height: 100%;
}

.cr-section__card {
    display: flex !important;
    flex-direction: column !important;
    height: 100%;
    min-height: clamp(360px, 32vw, 520px);
    padding: clamp(1.25rem, 2.8vw, 2.25rem);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 18px 48px rgba(31, 20, 20, 0.04);
}

.cr-section__card-image {
    flex: 0 0 auto;
    width: 100%;
    margin: 0 0 1rem;
}

.cr-section__card-image img {
    aspect-ratio: 900 / 537;
    object-fit: cover;
}

.cr-section__card-body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
}

.cr-section__card-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-section__card-meta {
    margin-top: auto;
}

/* Sidebar de Más artículos: presente en single y home, sin widgets laterales genéricos. */
.cr-sidebar-more {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
    padding: clamp(1.1rem, 2.4vw, 1.5rem);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    background: var(--wp--preset--color--bg-soft, #FCF7F7);
}

.cr-sidebar-more__title {
    margin: 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2rem);
    font-weight: 900;
    letter-spacing: -0.02em;
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-sidebar-more .cr-sidebar-more__list,
.cr-sidebar-more .wp-block-post-template {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: clamp(1rem, 2vw, 1.35rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-sidebar-more .wp-block-post {
    width: 100%;
    max-width: 100% !important;
}

.cr-sidebar-more__item {
    display: flex;
    flex-direction: column;
    gap: 0.65rem;
    width: 100%;
    max-width: 100%;
    padding-bottom: clamp(1rem, 2vw, 1.35rem);
    border-bottom: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-sidebar-more__list > li:last-child .cr-sidebar-more__item {
    padding-bottom: 0;
    border-bottom: 0;
}

.cr-sidebar-more__image {
    position: relative;
    margin: 0;
    overflow: hidden;
    border-radius: 3px;
}

.cr-sidebar-more__badge {
    display: inline-block;
    width: fit-content;
    padding: 4px 8px;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    line-height: 1.2;
    text-transform: uppercase;
}

.cr-sidebar-more__badge a {
    color: inherit;
    text-decoration: none;
}

.cr-sidebar-more__badge:empty {
    display: none;
}

.cr-sidebar-more__post-title {
    display: -webkit-box;
    margin: 0;
    overflow: hidden;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1rem, 0.92rem + 0.45vw, 1.22rem);
    font-weight: 800;
    line-height: 1.18;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-sidebar-more__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-sidebar-more__post-title a:hover,
.cr-sidebar-more__post-title a:focus-visible {
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-sidebar-more__meta {
    gap: 0.5rem !important;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.76rem;
}

.cr-sidebar-more__author {
    color: var(--wp--preset--color--text-strong, #000000);
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.cr-sidebar-home {
    display: grid;
    gap: clamp(1rem, 2vw, 1.5rem);
    margin-top: clamp(1rem, 2vw, 1.5rem);
}

/* Recursos para descargar: cards más limpias, CTA real y ratio editorial estable. */
.cr-slider-pdfs {
    padding: clamp(4rem, 8vw, 6rem) 0;
    background:
        linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 28%),
        var(--wp--preset--color--bg, #FFFFFF);
}

.cr-slider-pdfs .cr-slider-pdfs__track {
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    padding: 0.25rem 0 1.25rem;
}

.cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
.cr-slider-pdfs .cr-slider-pdfs__track > * {
    flex-basis: calc((100% - 3.5rem) / 3) !important;
}

.cr-slider-pdfs .cr-slider-pdfs__card {
    display: flex;
    flex-direction: column;
    min-height: 100%;
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image {
    margin: 0 0 1rem;
    border-radius: 12px;
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    object-fit: cover;
    box-shadow: none;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    display: -webkit-box;
    min-height: 3.9em;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-slider-pdfs .cr-slider-pdfs__cta {
    display: inline-flex;
    border-radius: 999px;
    min-height: 44px;
    align-items: center;
    justify-content: center;
    gap: 0.55rem;
    padding: 0.78rem 1.1rem;
    background: var(--wp--preset--color--primary, #89100F);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    font-size: 0.82rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1;
    text-decoration: none;
    text-transform: uppercase;
    transition: transform 260ms var(--cr-motion-premium), background 260ms var(--cr-motion-premium);
}

.cr-slider-pdfs .cr-slider-pdfs__cta::after {
    content: "↓";
    display: inline-grid;
    width: 1.65rem;
    height: 1.65rem;
    place-items: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.16);
    font-size: 1rem;
    line-height: 1;
}

.cr-slider-pdfs .cr-slider-pdfs__cta:hover,
.cr-slider-pdfs .cr-slider-pdfs__cta:focus-visible {
    background: var(--wp--preset--color--text-strong, #000000);
    color: var(--wp--preset--color--on-primary, #FFFFFF);
    transform: translateY(-1px);
}

@media (max-width: 900px) {
    .cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }
}

@media (max-width: 600px) {
    .cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex-basis: 86% !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-slider-pdfs .cr-slider-pdfs__cta,
    .cr-section__card,
    .cr-sidebar-more__item {
        transition: none !important;
        transform: none !important;
    }
}



/* UXR14 - final audit fixes: universal sidebar badges, recommendation frame and mobile nav. */
.cr-sidebar-more .cr-sidebar-more__item,
.cr-sidebar-more .wp-block-post {
    position: relative;
}

.cr-sidebar-more__badge {
    position: absolute;
    top: clamp(0.7rem, 2vw, 0.95rem);
    left: 50%;
    z-index: 2;
    margin: 0;
    transform: translateX(-50%);
    box-shadow: 0 8px 24px rgba(33, 18, 18, 0.18);
}

.cr-sidebar__cover {
    padding: clamp(0.85rem, 2vw, 1rem);
    border: 1px solid rgba(137, 16, 15, 0.16);
    border-radius: 18px;
    background:
        radial-gradient(circle at 50% 10%, rgba(255, 255, 255, 0.2), transparent 36%),
        linear-gradient(145deg, rgba(137, 16, 15, 0.96), rgba(69, 8, 8, 0.98));
    box-shadow: 0 22px 60px rgba(32, 12, 12, 0.12);
}

.cr-sidebar__cover img {
    max-height: 440px;
    object-fit: contain;
    border: 1px solid rgba(255, 255, 255, 0.45);
    border-radius: 12px;
    background: #FFFFFF;
}

@media (max-width: 600px) {
    .cr-header .cr-header__nav .wp-block-navigation__responsive-container-content .wp-block-navigation-item__content {
        max-width: min(13ch, calc(100vw - 2rem));
        font-size: clamp(1.72rem, 10.4vw, 3.35rem);
        overflow-wrap: anywhere;
    }
}



/* ============================================================
 * UXR15 ? home editorial premium, badges externos y grids variados.
 * Contrato: badge fuera de la imagen, media 900/537, simetr?a por card.
 * ============================================================ */

.cr-card,
.cr-grid-2col .wp-block-post-template > li,
.cr-grid-3col .wp-block-post-template > li,
.cr-grid-4col .wp-block-post-template > li,
.cr-grid-magazine .wp-block-post-template > li,
.cr-slider .cr-scroll-rail > li,
.cr-home-slider .cr-scroll-rail > li,
.cr-slider-pdfs .cr-scroll-rail > li {
    display: flex;
    flex-direction: column;
    min-width: 0;
    height: 100%;
}

.cr-card__badge,
.cr-grid-hero__badge,
.cr-grid-hero__lead-badge,
.cr-grid-2col__badge,
.cr-grid-3col__badge,
.cr-grid-4col__badge,
.cr-grid-magazine__badge,
.cr-slider__badge,
.cr-home-slider__badge,
.cr-trending__badge,
.cr-trending__mini-badge,
.cr-divider-grid__badge,
.cr-spotlight-mosaic__badge,
.cr-text-grid__badge,
.cr-slider-pdfs__badge,
.cr-archive__badge,
.cr-single__related-badge,
.cr-sidebar-more__badge,
.cr-section__card-badge {
    position: static !important;
    inset: auto !important;
    z-index: auto;
    display: inline-flex;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    margin: 0 0 0.65rem !important;
    padding: 0.38rem 0.68rem;
    border-radius: 2px;
    background: var(--wp--preset--color--primary, #89100F);
    box-shadow: none !important;
    color: var(--wp--preset--color--on-primary, #FFFFFF) !important;
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.08em;
    line-height: 1.15;
    text-decoration: none;
    text-shadow: none !important;
    text-transform: uppercase;
    transform: none !important;
    font-feature-settings: "smcp" 1, "c2sc" 1;
    font-variant-caps: all-small-caps;
}

.cr-card__badge a,
.cr-grid-hero__badge a,
.cr-grid-hero__lead-badge a,
.cr-grid-2col__badge a,
.cr-grid-3col__badge a,
.cr-grid-4col__badge a,
.cr-grid-magazine__badge a,
.cr-slider__badge a,
.cr-home-slider__badge a,
.cr-trending__badge a,
.cr-trending__mini-badge a,
.cr-divider-grid__badge a,
.cr-spotlight-mosaic__badge a,
.cr-text-grid__badge a,
.cr-slider-pdfs__badge a,
.cr-archive__badge a,
.cr-single__related-badge a,
.cr-sidebar-more__badge a,
.cr-section__card-badge a {
    color: inherit !important;
    text-decoration: none;
}

.cr-card__badge:empty,
.cr-grid-hero__badge:empty,
.cr-grid-hero__lead-badge:empty,
.cr-grid-2col__badge:empty,
.cr-grid-3col__badge:empty,
.cr-grid-4col__badge:empty,
.cr-grid-magazine__badge:empty,
.cr-slider__badge:empty,
.cr-home-slider__badge:empty,
.cr-trending__badge:empty,
.cr-trending__mini-badge:empty,
.cr-divider-grid__badge:empty,
.cr-spotlight-mosaic__badge:empty,
.cr-text-grid__badge:empty,
.cr-slider-pdfs__badge:empty,
.cr-archive__badge:empty,
.cr-single__related-badge:empty,
.cr-sidebar-more__badge:empty,
.cr-section__card-badge:empty {
    display: none;
}

.cr-badge-card .cr-badge-card__media::before,
.cr-grid-hero .wp-block-post-featured-image::before,
.cr-grid-2col .wp-block-post-featured-image::before,
.cr-grid-3col .wp-block-post-featured-image::before,
.cr-grid-4col .wp-block-post-featured-image::before,
.cr-grid-magazine .wp-block-post-featured-image::before,
.cr-archive .wp-block-post-featured-image::before,
.cr-single__related-image::before {
    display: none;
}

.cr-card__media,
.cr-card .wp-block-post-featured-image,
.cr-grid-2col .wp-block-post-featured-image,
.cr-grid-3col .wp-block-post-featured-image,
.cr-grid-4col .wp-block-post-featured-image,
.cr-grid-magazine .wp-block-post-featured-image,
.cr-slider .wp-block-post-featured-image,
.cr-home-slider .wp-block-post-featured-image,
.cr-trending .wp-block-post-featured-image,
.cr-divider-grid .wp-block-post-featured-image,
.cr-spotlight-mosaic .wp-block-post-featured-image,
.cr-slider-pdfs .wp-block-post-featured-image,
.cr-archive .wp-block-post-featured-image,
.cr-sidebar-more .wp-block-post-featured-image {
    position: relative;
    width: 100%;
    margin: 0 0 1rem;
    overflow: hidden;
}

.cr-card__media img,
.cr-card .wp-block-post-featured-image img,
.cr-grid-2col .wp-block-post-featured-image img,
.cr-grid-3col .wp-block-post-featured-image img,
.cr-grid-4col .wp-block-post-featured-image img,
.cr-grid-magazine .wp-block-post-featured-image img,
.cr-slider .wp-block-post-featured-image img,
.cr-home-slider .wp-block-post-featured-image img,
.cr-trending .wp-block-post-featured-image img,
.cr-divider-grid .wp-block-post-featured-image img,
.cr-spotlight-mosaic .wp-block-post-featured-image img,
.cr-slider-pdfs .wp-block-post-featured-image img,
.cr-archive .wp-block-post-featured-image img,
.cr-sidebar-more .wp-block-post-featured-image img {
    aspect-ratio: 900 / 537;
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

.cr-card__body,
.cr-home-slider__body,
.cr-trending__feature-body,
.cr-divider-grid__body,
.cr-spotlight-mosaic__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-width: 0;
}

.cr-card__title,
.cr-grid-3col .wp-block-post-title,
.cr-home-slider__post-title,
.cr-trending__mini-title,
.cr-divider-grid__title,
.cr-spotlight-mosaic__post-title,
.cr-sidebar-more__post-title,
.cr-slider-pdfs__post-title {
    display: -webkit-box;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.cr-card__meta,
.cr-grid-3col__meta,
.cr-home-slider__meta,
.cr-divider-grid__meta,
.cr-sidebar-more__meta,
.cr-slider-pdfs__author,
.cr-card__button {
    margin-top: auto;
}

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    display: inline-flex;
    width: fit-content;
    min-height: 38px;
    align-items: center;
    justify-content: center;
    margin-top: 1rem;
    padding: 0.5rem 0.78rem;
    border: 1px solid rgba(137, 16, 15, 0.35);
    border-radius: 3px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: var(--wp--preset--font-size--xs, 0.75rem);
    font-weight: 900;
    letter-spacing: 0.09em;
    line-height: 1.15;
    text-decoration: none;
    text-transform: uppercase;
}

.cr-card__button:hover,
.cr-card__button:focus-visible,
.cr-trending__button:hover,
.cr-trending__button:focus-visible,
.cr-home-slider__button:hover,
.cr-home-slider__button:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-scroll-section {
    padding-block: clamp(3.5rem, 8vw, 6rem);
}

.cr-scroll-rail {
    display: flex !important;
    gap: clamp(1rem, 2.5vw, 1.75rem) !important;
    overflow-x: auto;
    scroll-behavior: smooth;
    scroll-padding-inline: 1px;
    scroll-snap-type: x mandatory;
    padding: 0.25rem 0 1.25rem;
    list-style: none;
    scrollbar-color: var(--wp--preset--color--primary, #89100F) rgba(137, 16, 15, 0.12);
}

.cr-scroll-rail > li,
.cr-scroll-rail > .wp-block-post,
.cr-scroll-rail > * {
    flex: 0 0 calc((100% - 3.5rem) / 3) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider {
    background: linear-gradient(180deg, rgba(137, 16, 15, 0.035), transparent 34%);
}

.cr-home-slider__card,
.cr-slider .cr-slider__card,
.cr-slider-pdfs .cr-slider-pdfs__card {
    padding: clamp(1rem, 2vw, 1.35rem);
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 18px;
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.06);
}

.cr-home-slider__post-title,
.cr-home-slider .cr-card__title {
    margin: 0 0 0.9rem;
    color: var(--wp--preset--color--text-strong, #000000);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.35rem, 1.05rem + 0.9vw, 2rem);
    font-weight: 900;
    line-height: 1.05;
}

.cr-trending {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-trending__layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
    gap: clamp(2rem, 5vw, 4rem);
    align-items: start;
}

.cr-trending__feature-template,
.cr-trending__grid {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-trending__feature {
    min-height: 100%;
}

.cr-trending__feature-title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.35rem, 1.45rem + 4.2vw, 5rem);
    font-weight: 500;
    line-height: 0.96;
    letter-spacing: -0.045em;
}

.cr-trending__grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem);
}

.cr-trending__mini-title {
    margin: 0.55rem 0 0;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.05rem, 0.92rem + 0.5vw, 1.35rem);
    line-height: 1.16;
}

.cr-divider-grid-section {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
}

.cr-divider-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin: 0;
    padding: 0;
    list-style: none;
    background: var(--wp--preset--color--bg, #FFFFFF);
    border: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li {
    min-width: 0;
    border-left: 1px solid var(--wp--preset--color--rule, #E4E8ED);
}

.cr-divider-grid > li:first-child {
    border-left: 0;
}

.cr-divider-grid__item {
    min-height: clamp(500px, 40vw, 620px);
    padding: clamp(1.25rem, 3vw, 2.35rem);
    background: var(--wp--preset--color--bg, #FFFFFF);
    box-shadow: none;
}

.cr-divider-grid__title {
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.45rem, 1.1rem + 1vw, 2.15rem);
    font-weight: 900;
    line-height: 1.04;
}

.cr-spotlight-mosaic {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-spotlight-mosaic__title {
    position: relative;
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: var(--wp--preset--color--text-strong, #000000);
}

.cr-spotlight-mosaic__title::before,
.cr-spotlight-mosaic__title::after {
    content: "";
    display: inline-block;
    width: min(14vw, 160px);
    height: 1px;
    margin-inline: 1.5rem;
    vertical-align: middle;
    background: currentColor;
    opacity: 0.5;
}

.cr-spotlight-mosaic__grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 4px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-spotlight-mosaic__grid > li {
    min-width: 0;
}

.cr-spotlight-mosaic__grid > li:first-child {
    grid-column: span 2;
    grid-row: span 2;
}

.cr-spotlight-mosaic__item {
    min-height: 100%;
    padding: clamp(0.85rem, 2vw, 1.2rem);
    border: 1px solid rgba(137, 16, 15, 0.1);
    background: var(--wp--preset--color--bg-soft, #F8F5F2);
}

.cr-spotlight-mosaic__grid > li:first-child .cr-spotlight-mosaic__post-title {
    font-size: clamp(2rem, 1.25rem + 3vw, 4rem);
    line-height: 0.98;
}

.cr-text-grid-section {
    background: var(--wp--preset--color--bg, #FFFFFF);
}

.cr-text-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    column-gap: clamp(2rem, 6vw, 5rem);
    row-gap: clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-text-grid__item {
    padding-block: 1rem 1.5rem;
    border-top: 1px solid rgba(0, 0, 0, 0.32);
}

.cr-text-grid__title {
    margin: 0.75rem 0 0.8rem;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 2rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-text-grid__excerpt {
    color: var(--wp--preset--color--muted-strong, #666666);
}

.cr-grid-3col__card,
.cr-home__more .cr-grid-3col .wp-block-post-template > li {
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cr-grid-3col .cr-grid-3col__title,
.cr-grid-3col .wp-block-post-title {
    margin-block: 0 0.75rem;
    color: var(--wp--preset--color--primary, #89100F);
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.25rem, 1rem + 0.85vw, 1.75rem);
    font-weight: 500;
    line-height: 1.08;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    margin: 0.2rem 0 0.75rem;
    text-align: center;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.55vw, 1.35rem);
    line-height: 1.12;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-top: auto;
    margin-bottom: 1rem;
    text-align: center;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cr-sidebar-more__item,
.cr-sidebar-more .cr-sidebar-more__item {
    position: static;
}

.cr-sidebar-more__badge {
    align-self: flex-start;
}

@media (max-width: 900px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: calc((100% - 1rem) / 2) !important;
    }

    .cr-trending__layout,
    .cr-divider-grid,
    .cr-spotlight-mosaic__grid,
    .cr-text-grid,
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }

    .cr-divider-grid > li {
        border-left: 0;
        border-top: 1px solid var(--wp--preset--color--rule, #E4E8ED);
    }

    .cr-divider-grid > li:first-child {
        border-top: 0;
    }

    .cr-spotlight-mosaic__grid > li:first-child {
        grid-column: auto;
        grid-row: auto;
    }
}

@media (max-width: 600px) {
    .cr-scroll-rail > li,
    .cr-scroll-rail > .wp-block-post,
    .cr-scroll-rail > * {
        flex-basis: 86% !important;
    }

    .cr-trending__grid {
        grid-template-columns: 1fr;
    }

    .cr-spotlight-mosaic__title::before,
    .cr-spotlight-mosaic__title::after {
        width: 18vw;
        margin-inline: 0.7rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-scroll-rail {
        scroll-behavior: auto !important;
    }

    .cr-card,
    .cr-card img,
    .cr-card__button {
        transition: none !important;
        transform: none !important;
    }
}



.cr-issue-list {
    padding-inline: var(--wp--preset--spacing--40, 1.5rem);
    background: #1F2024;
    color: #FFFFFF;
}

.cr-issue-list__title {
    margin-bottom: clamp(2rem, 5vw, 4rem);
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(2.25rem, 1.25rem + 4vw, 4.75rem);
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.cr-issue-list__grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(1.25rem, 3vw, 2rem) clamp(2rem, 5vw, 4rem);
    margin: 0;
    padding: 0;
    list-style: none;
}

.cr-issue-list__item {
    display: grid !important;
    grid-template-columns: minmax(92px, 0.34fr) minmax(0, 1fr);
    gap: 1rem !important;
    align-items: start;
    padding-block: 0 1.35rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    color: #FFFFFF;
}

.cr-issue-list__badge {
    grid-column: 1 / -1;
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-issue-list .wp-block-post-featured-image {
    margin: 0;
}

.cr-issue-list__post-title {
    margin: 0.35rem 0 0.5rem;
    color: #FFFFFF;
    font-family: var(--wp--preset--font-family--display, Georgia, serif);
    font-size: clamp(1.08rem, 0.92rem + 0.5vw, 1.45rem);
    font-weight: 800;
    line-height: 1.1;
}

.cr-issue-list__post-title a {
    color: inherit;
    text-decoration: none;
}

.cr-issue-list__date,
.cr-issue-list__excerpt {
    color: rgba(255, 255, 255, 0.72);
}

@media (max-width: 900px) {
    .cr-issue-list__grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 600px) {
    .cr-issue-list__item {
        grid-template-columns: 1fr;
    }
}



/* UXR15.1 ? keep premium home sections wide; core constrained groups inside post-template otherwise shrink cards. */
.cr-home-slider,
.cr-trending,
.cr-spotlight-mosaic,
.cr-issue-list,
.cr-text-grid-section,
.cr-slider-pdfs {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
}

.cr-home-slider > :where(.wp-block-query, .wp-block-group),
.cr-home-slider__query,
.cr-home-slider__track,
.cr-trending__layout,
.cr-trending__feature-query,
.cr-trending__grid-query,
.cr-trending__feature-template,
.cr-trending__grid,
.cr-spotlight-mosaic__query,
.cr-spotlight-mosaic__grid,
.cr-issue-list__query,
.cr-issue-list__grid,
.cr-text-grid-section .wp-block-query,
.cr-text-grid,
.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-card.has-global-padding,
.cr-card.is-layout-constrained {
    padding-left: 0;
    padding-right: 0;
}

.cr-home-slider__card.has-global-padding,
.cr-slider-pdfs__card.has-global-padding {
    padding: clamp(1rem, 2vw, 1.35rem) !important;
}

.cr-divider-grid__item.has-global-padding,
.cr-spotlight-mosaic__item.has-global-padding {
    padding: clamp(1.25rem, 3vw, 2.35rem) !important;
}

.cr-card > :where(.wp-block-post-terms, .wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    max-width: none !important;
}

.cr-card > :where(.wp-block-post-featured-image, .wp-block-group, .wp-block-post-title, .wp-block-post-excerpt, .wp-block-post-author-name, .wp-block-read-more),
.cr-card .wp-block-post-featured-image,
.cr-card .wp-block-post-featured-image a,
.cr-card .wp-block-post-featured-image img {
    width: 100% !important;
}

.cr-card > .wp-block-post-terms,
.cr-card__badge {
    width: fit-content !important;
}

/* stylelint-enable no-descending-specificity */


/* ============================================================
 * UXR19 ? Single sin sidebar, hero slider real y Vivir la fe legible.
 * ============================================================ */
/* stylelint-disable no-descending-specificity */

.cr-single.wp-block-group {
    max-width: none;
}

.cr-single__article-shell {
    width: 100%;
    max-width: min(100% - 32px, 980px);
    margin-inline: auto;
}

.cr-single__article-shell > :where(.cr-single__header, .cr-single__content, .cr-share-buttons, .cr-author-card) {
    width: 100%;
    max-width: none !important;
}

.cr-single .cr-single__header {
    max-width: min(100%, 900px);
}

.cr-single .cr-single__hero,
.cr-single .cr-single__hero img {
    width: 100%;
    max-width: none !important;
}

.cr-single .cr-single__hero img {
    aspect-ratio: 900 / 537;
    object-fit: cover;
}

.cr-single__related-shell {
    width: 100%;
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin: clamp(4rem, 8vw, 7rem) auto 0;
}

.cr-single__related-shell > .cr-related-posts,
.cr-single__related-shell .cr-related-posts {
    width: 100%;
    max-width: none !important;
}

.cr-home-slider--hero {
    position: relative;
    padding-block: clamp(4rem, 8vw, 7rem);
    background:
        linear-gradient(180deg, rgba(137, 16, 15, 0.055), rgba(137, 16, 15, 0) 42%),
        var(--wp--preset--color--bg, #FFFFFF);
}

.cr-home-slider--hero .cr-home-slider__viewport,
.cr-home-slider--hero .cr-home-slider__query,
.cr-home-slider--hero .cr-home-slider__track {
    width: 100%;
    max-width: none !important;
}

.cr-home-slider--hero .cr-home-slider__track.wp-block-post-template {
    align-items: stretch;
    gap: clamp(1.1rem, 2.5vw, 1.75rem) !important;
    padding: 0.35rem 0 clamp(1.35rem, 3vw, 2rem);
    scroll-padding-inline: 0;
}

.cr-home-slider--hero .cr-home-slider__track.wp-block-post-template > li {
    flex: 0 0 min(920px, calc(100vw - 64px)) !important;
    max-width: 920px !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-home-slider--hero .cr-home-slider__card.has-global-padding,
.cr-home-slider--hero .cr-home-slider__card {
    height: 100%;
    padding: clamp(0.9rem, 2vw, 1.25rem) !important;
    overflow: hidden;
    border: 1px solid rgba(137, 16, 15, 0.14);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 30px 90px rgba(31, 20, 20, 0.1);
}

.cr-home-slider--hero .cr-home-slider__badge {
    margin: 0 0 0.75rem !important;
}

.cr-home-slider--hero .cr-home-slider__image,
.cr-home-slider--hero .cr-home-slider__image a,
.cr-home-slider--hero .cr-home-slider__image img {
    width: 100% !important;
    max-width: none !important;
}

.cr-home-slider--hero .cr-home-slider__image {
    margin: 0 !important;
    border-radius: 14px;
}

.cr-home-slider--hero .cr-home-slider__image img {
    aspect-ratio: 900 / 537;
    object-fit: cover;
}

.cr-home-slider--hero .cr-home-slider__body {
    gap: 0.9rem;
    padding: clamp(1rem, 2.4vw, 1.75rem) 0 0;
}

.cr-home-slider--hero .cr-home-slider__post-title,
.cr-home-slider--hero .cr-card__title {
    max-width: 17ch;
    margin: 0;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: clamp(2.1rem, 1.25rem + 3vw, 4.25rem);
    line-height: 0.98;
    -webkit-line-clamp: 3;
}

.cr-home-slider--hero .cr-home-slider__excerpt {
    max-width: 58ch;
    color: var(--wp--preset--color--muted-strong, #666666);
    font-size: clamp(0.98rem, 0.92rem + 0.24vw, 1.1rem);
    line-height: 1.55;
}

.cr-home-slider--hero .cr-home-slider__controls {
    display: flex;
    gap: 0.65rem;
    align-items: center;
    justify-content: center;
    margin-top: clamp(0.5rem, 1.5vw, 1rem);
}

.cr-home-slider__control,
.cr-home-slider__dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(137, 16, 15, 0.22);
    background: rgba(255, 255, 255, 0.86);
    color: var(--wp--preset--color--primary, #89100F);
    cursor: pointer;
    transition: background 220ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        border-color 220ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        transform 220ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1));
}

.cr-home-slider__control {
    width: 42px;
    height: 42px;
    border-radius: 50%;
    font-size: 1.5rem;
    line-height: 1;
}

.cr-home-slider__dot {
    width: 2rem;
    height: 0.38rem;
    padding: 0;
    border-radius: 999px;
    font-size: 0;
}

.cr-home-slider__dot.is-current,
.cr-home-slider__dot[aria-current="true"],
.cr-home-slider__control:hover,
.cr-home-slider__control:focus-visible,
.cr-home-slider__dot:hover,
.cr-home-slider__dot:focus-visible {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-1px);
}

.cr-section--vivir-la-fe {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
    padding-inline: clamp(1rem, 2.5vw, 1.5rem);
}

.cr-section--vivir-la-fe .cr-divider-grid__query {
    width: 100%;
    max-width: none !important;
}

.cr-section--vivir-la-fe .cr-divider-grid {
    width: 100%;
    max-width: none !important;
    border-color: rgba(137, 16, 15, 0.14);
    box-shadow: 0 22px 70px rgba(31, 20, 20, 0.045);
}

.cr-divider-grid__item.has-global-padding {
    min-height: auto;
    padding: clamp(1.25rem, 2.2vw, 1.8rem) !important;
}

.cr-divider-grid__item {
    min-height: auto;
}

.cr-divider-grid__title {
    font-size: clamp(1.35rem, 1rem + 0.95vw, 1.95rem);
    line-height: 1.08;
    -webkit-line-clamp: 4;
}

.cr-divider-grid__excerpt {
    display: -webkit-box;
    overflow: hidden;
    color: var(--wp--preset--color--text, #202020);
    line-height: 1.62;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 5;
}

@media (max-width: 900px) {
    .cr-home-slider--hero .cr-home-slider__track.wp-block-post-template > li {
        flex-basis: min(86vw, 760px) !important;
        max-width: min(86vw, 760px) !important;
    }

    .cr-home-slider--hero .cr-home-slider__post-title,
    .cr-home-slider--hero .cr-card__title {
        font-size: clamp(1.8rem, 1.3rem + 3vw, 3rem);
    }

    .cr-section--vivir-la-fe {
        width: min(100% - 32px, 760px);
        max-width: min(100% - 32px, 760px);
    }
}

@media (max-width: 600px) {
    .cr-single__article-shell,
    .cr-single__related-shell {
        max-width: min(100% - 28px, 100%);
    }

    .cr-home-slider--hero .cr-home-slider__track.wp-block-post-template > li {
        flex-basis: 88% !important;
        max-width: 88% !important;
    }

    .cr-home-slider--hero .cr-home-slider__card.has-global-padding,
    .cr-home-slider--hero .cr-home-slider__card {
        border-radius: 16px;
        padding: 0.85rem !important;
    }

    .cr-home-slider__control {
        width: 44px;
        height: 44px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-home-slider__control,
    .cr-home-slider__dot {
        transition: none !important;
        transform: none !important;
    }
}

/* stylelint-enable no-descending-specificity */

/* ============================================================
 * UXR21 - CTAs editoriales: proporción horizontal, no cuadrados/círculos.
 * ============================================================ */
/* stylelint-disable no-descending-specificity */

.cr-card__button,
.cr-trending__button,
.cr-home-slider__button {
    box-sizing: border-box;
    min-width: clamp(6rem, 7vw, 7.5rem);
    min-height: 44px;
    padding: 0.62rem 1.15rem;
}

/* stylelint-enable no-descending-specificity */

/* ============================================================
 * UXR22 - slider controls: hit areas accesibles sin agrandar la barra visible.
 * ============================================================ */
/* stylelint-disable no-descending-specificity */

.cr-home-slider__control {
    width: 44px;
    height: 44px;
}

.cr-home-slider__dot {
    position: relative;
    width: 44px;
    min-width: 44px;
    height: 44px;
    min-height: 44px;
    border: 0;
    background: transparent;
}

.cr-home-slider__dot::before {
    content: "";
    display: block;
    width: 2rem;
    height: 0.38rem;
    border: 1px solid rgba(137, 16, 15, 0.22);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.86);
    transition: background 220ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        border-color 220ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1));
}

.cr-home-slider__dot.is-current,
.cr-home-slider__dot[aria-current="true"],
.cr-home-slider__dot:hover,
.cr-home-slider__dot:focus-visible {
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
}

.cr-home-slider__dot.is-current::before,
.cr-home-slider__dot[aria-current="true"]::before,
.cr-home-slider__dot:hover::before,
.cr-home-slider__dot:focus-visible::before {
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
}

/* stylelint-enable no-descending-specificity */

/* ============================================================
 * UXR23 — slider hero real + recursos premium sin scrollbar nativa.
 * ============================================================ */
/* stylelint-disable no-descending-specificity */

.cr-home-slider--hero {
    overflow: hidden;
    padding-block: clamp(4.5rem, 8vw, 7.5rem);
    background:
        radial-gradient(circle at 12% 10%, rgba(137, 16, 15, 0.08), transparent 34rem),
        linear-gradient(180deg, rgba(137, 16, 15, 0.035), rgba(255, 255, 255, 0) 46%),
        var(--wp--preset--color--bg, #FFFFFF);
}

.cr-home-slider--hero .cr-home-slider__header {
    width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    max-width: var(--cr-visual-wide, min(100% - 48px, 1180px));
    margin-inline: auto;
    margin-bottom: clamp(1.8rem, 4vw, 3rem);
}

.cr-home-slider--hero .cr-home-slider__viewport,
.cr-home-slider--hero .cr-home-slider__query,
.cr-home-slider--hero .cr-home-slider__track {
    width: 100%;
    max-width: none !important;
}

.cr-home-slider--hero .cr-home-slider__viewport {
    position: relative;
    overflow: hidden;
}

.cr-home-slider--hero .cr-home-slider__track.wp-block-post-template {
    align-items: stretch;
    gap: clamp(1rem, 2vw, 1.5rem) !important;
    overflow-x: auto !important;
    padding: 0 max(1.5rem, calc((100vw - 1120px) / 2)) clamp(1.2rem, 2vw, 1.6rem) !important;
    scroll-padding-inline: max(1.5rem, calc((100vw - 1120px) / 2));
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.cr-home-slider--hero .cr-home-slider__track::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}

.cr-home-slider--hero .cr-home-slider__track.wp-block-post-template > li {
    flex: 0 0 min(1120px, calc(100vw - 48px)) !important;
    max-width: min(1120px, calc(100vw - 48px)) !important;
    min-width: 0;
    scroll-snap-align: center;
}

.cr-home-slider--hero .cr-home-slider__card.has-global-padding,
.cr-home-slider--hero .cr-home-slider__card {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
    grid-template-areas: "body media";
    gap: clamp(1.5rem, 4vw, 4rem);
    align-items: center;
    min-height: auto;
    padding: clamp(1rem, 2.2vw, 1.45rem) !important;
    overflow: hidden;
    border: 1px solid rgba(137, 16, 15, 0.13);
    border-radius: 28px;
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(252, 247, 247, 0.92)),
        #FFFFFF;
    box-shadow:
        0 34px 110px rgba(31, 20, 20, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 0.75);
    transition: transform 520ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        box-shadow 520ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1));
}

.cr-home-slider--hero .cr-home-slider__track > li.is-active .cr-home-slider__card,
.cr-home-slider--hero .cr-home-slider__card:hover {
    transform: translateY(-2px);
    box-shadow:
        0 40px 120px rgba(31, 20, 20, 0.15),
        inset 0 1px 0 rgba(255, 255, 255, 0.82);
}

.cr-home-slider--hero .cr-home-slider__badge {
    grid-area: badge;
    align-self: end;
    justify-self: start;
    margin: 0 !important;
}

.cr-home-slider--hero .cr-home-slider__image {
    grid-area: media;
    margin: 0 !important;
    overflow: hidden;
    border-radius: 18px;
    background: rgba(137, 16, 15, 0.06);
}

.cr-home-slider--hero .cr-home-slider__image,
.cr-home-slider--hero .cr-home-slider__image a,
.cr-home-slider--hero .cr-home-slider__image img {
    width: 100% !important;
    max-width: none !important;
}

.cr-home-slider--hero .cr-home-slider__image img {
    display: block;
    aspect-ratio: 900 / 537;
    object-fit: cover;
}

.cr-home-slider--hero .cr-home-slider__body {
    grid-area: body;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: clamp(0.75rem, 1.8vw, 1.1rem);
    min-width: 0;
    padding: clamp(0.25rem, 1vw, 0.75rem) 0 !important;
}

.cr-home-slider--hero .cr-home-slider__post-title,
.cr-home-slider--hero .cr-card__title {
    max-width: 14ch;
    margin: 0;
    color: var(--wp--preset--color--primary, #89100F);
    font-size: clamp(2.2rem, 1.35rem + 3.1vw, 4.6rem);
    line-height: 0.94;
    letter-spacing: -0.035em;
    -webkit-line-clamp: 3;
}

.cr-home-slider--hero .cr-home-slider__excerpt {
    display: none !important;
}

.cr-home-slider--hero .cr-home-slider__meta {
    gap: 0.55rem 0.8rem;
    margin-top: 0.15rem;
    color: rgba(32, 32, 32, 0.68);
    font-size: 0.72rem;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.cr-home-slider--hero .cr-home-slider__button {
    margin-top: clamp(0.45rem, 1.5vw, 0.8rem);
}

.cr-home-slider--hero .cr-home-slider__controls {
    display: grid;
    grid-template-columns: 48px minmax(0, 1fr) 48px;
    gap: clamp(0.55rem, 1.4vw, 0.85rem);
    align-items: center;
    width: min(100% - 48px, 1120px);
    margin: clamp(0.85rem, 2vw, 1.35rem) auto 0;
}

.cr-home-slider__control {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(137, 16, 15, 0.2);
    border-radius: 999px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(252, 247, 247, 0.88));
    color: var(--wp--preset--color--primary, #89100F);
    box-shadow: 0 16px 44px rgba(31, 20, 20, 0.11);
    cursor: pointer;
    font-size: 1.35rem;
    line-height: 1;
    transition: transform 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        background 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        color 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1));
}

.cr-home-slider__control:hover,
.cr-home-slider__control:focus-visible {
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-2px);
}

.cr-home-slider__dots {
    display: flex;
    flex-wrap: wrap;
    gap: 0.15rem;
    align-items: center;
    justify-content: center;
}

.cr-home-slider__dot {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    min-width: 44px;
    height: 44px;
    min-height: 44px;
    padding: 0;
    border: 0;
    border-radius: 999px;
    background: transparent;
    color: var(--wp--preset--color--primary, #89100F);
    cursor: pointer;
}

.cr-home-slider__dot::before {
    content: "";
    display: block;
    width: 1.45rem;
    height: 0.28rem;
    border: 1px solid rgba(137, 16, 15, 0.18);
    border-radius: 999px;
    background: rgba(137, 16, 15, 0.14);
    transition: width 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        background 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1));
}

.cr-home-slider__dot.is-current::before,
.cr-home-slider__dot[aria-current="true"]::before,
.cr-home-slider__dot:hover::before,
.cr-home-slider__dot:focus-visible::before {
    width: 2.25rem;
    border-color: var(--wp--preset--color--primary, #89100F);
    background: var(--wp--preset--color--primary, #89100F);
}

.cr-slider-pdfs {
    position: relative;
    overflow: hidden;
    padding-block: clamp(4rem, 8vw, 6.5rem);
    background:
        linear-gradient(180deg, rgba(137, 16, 15, 0.035), rgba(137, 16, 15, 0.075)),
        var(--wp--preset--color--bg-soft, #FCF7F7);
}

.cr-slider-pdfs .cr-slider-pdfs__hint {
    display: none;
}

.cr-slider-pdfs > .wp-block-query,
.cr-slider-pdfs .cr-slider-pdfs__track {
    width: 100%;
    max-width: none !important;
}

.cr-slider-pdfs .cr-slider-pdfs__track {
    gap: clamp(1rem, 2.4vw, 1.55rem) !important;
    overflow-x: auto !important;
    padding: 0.65rem max(1.5rem, calc((100vw - 1120px) / 2)) 1rem !important;
    scroll-padding-inline: max(1.5rem, calc((100vw - 1120px) / 2));
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.cr-slider-pdfs .cr-slider-pdfs__track::-webkit-scrollbar {
    display: none;
    width: 0;
    height: 0;
}

.cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
.cr-slider-pdfs .cr-slider-pdfs__track > * {
    flex: 0 0 clamp(286px, 29vw, 360px) !important;
    max-width: clamp(286px, 29vw, 360px) !important;
    min-width: 0;
    scroll-snap-align: start;
}

.cr-slider-pdfs .cr-slider-pdfs__card.has-global-padding,
.cr-slider-pdfs .cr-slider-pdfs__card {
    height: 100%;
    padding: clamp(1rem, 2vw, 1.35rem) !important;
    border: 1px solid rgba(137, 16, 15, 0.12);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow:
        0 24px 80px rgba(31, 20, 20, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image {
    overflow: hidden;
    margin: 0 !important;
    border-radius: 16px;
    background: rgba(137, 16, 15, 0.06);
}

.cr-slider-pdfs .cr-slider-pdfs__card .wp-block-post-featured-image img {
    display: block;
    width: 100%;
    max-width: none !important;
    aspect-ratio: 900 / 537;
    object-fit: cover;
}

.cr-slider-pdfs .cr-slider-pdfs__post-title {
    min-height: 0;
    margin: clamp(0.85rem, 1.8vw, 1.05rem) 0 0.55rem;
    color: var(--wp--preset--color--text-strong, #141414);
    font-size: clamp(1.2rem, 1rem + 0.65vw, 1.55rem);
    line-height: 1.06;
    letter-spacing: -0.02em;
    -webkit-line-clamp: 3;
}

.cr-slider-pdfs .cr-slider-pdfs__author {
    margin-bottom: clamp(0.8rem, 1.8vw, 1.05rem);
    color: rgba(32, 32, 32, 0.58);
    font-size: 0.68rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.cr-slider-pdfs .cr-slider-pdfs__cta-wrap {
    justify-content: flex-start !important;
}

.cr-slider-pdfs .cr-slider-pdfs__cta {
    display: inline-flex;
    gap: 0.7rem;
    align-items: center;
    justify-content: center;
    min-width: 10.5rem;
    border: 1px solid rgba(137, 16, 15, 0.26);
    border-radius: 999px;
    min-height: 44px;
    padding: 0.7rem 0.95rem 0.7rem 1.1rem;
    background: #FFFFFF;
    color: var(--wp--preset--color--primary, #89100F);
    box-shadow: 0 14px 38px rgba(31, 20, 20, 0.055);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    line-height: 1;
    text-decoration: none;
    text-transform: uppercase;
    transition: transform 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        background 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1)),
        color 260ms var(--cr-motion-premium, cubic-bezier(0.22, 1, 0.36, 1));
}

.cr-slider-pdfs .cr-slider-pdfs__cta::after {
    content: "↓";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.55rem;
    height: 1.55rem;
    border-radius: 999px;
    background: rgba(137, 16, 15, 0.08);
    color: inherit;
    font-size: 0.9rem;
    line-height: 1;
}

.cr-slider-pdfs .cr-slider-pdfs__cta:hover,
.cr-slider-pdfs .cr-slider-pdfs__cta:focus-visible {
    background: var(--wp--preset--color--primary, #89100F);
    color: #FFFFFF;
    transform: translateY(-2px);
}

@media (max-width: 900px) {
    .cr-home-slider--hero .cr-home-slider__card.has-global-padding,
    .cr-home-slider--hero .cr-home-slider__card {
        grid-template-columns: 1fr;
        grid-template-areas:
            "badge"
            "media"
            "body";
    }

    .cr-home-slider--hero .cr-home-slider__post-title,
    .cr-home-slider--hero .cr-card__title {
        max-width: 18ch;
        font-size: clamp(1.95rem, 1.35rem + 4vw, 3.45rem);
        -webkit-line-clamp: 2;
    }
}

@media (max-width: 600px) {
    .cr-home-slider--hero .cr-home-slider__track.wp-block-post-template {
        padding-inline: 1rem !important;
        scroll-padding-inline: 1rem;
    }

    .cr-home-slider--hero .cr-home-slider__track.wp-block-post-template > li {
        flex-basis: min(88vw, 440px) !important;
        max-width: min(88vw, 440px) !important;
    }

    .cr-home-slider--hero .cr-home-slider__card.has-global-padding,
    .cr-home-slider--hero .cr-home-slider__card,
    .cr-slider-pdfs .cr-slider-pdfs__card.has-global-padding,
    .cr-slider-pdfs .cr-slider-pdfs__card {
        border-radius: 18px;
    }

    .cr-home-slider--hero .cr-home-slider__controls {
        width: min(100% - 28px, 440px);
        grid-template-columns: 44px minmax(0, 1fr) 44px;
    }

    .cr-home-slider__control {
        width: 44px;
        height: 44px;
    }

    .cr-slider-pdfs .cr-slider-pdfs__track {
        padding-inline: 1rem !important;
        scroll-padding-inline: 1rem;
    }

    .cr-slider-pdfs .cr-slider-pdfs__track > .wp-block-post,
    .cr-slider-pdfs .cr-slider-pdfs__track > * {
        flex-basis: min(84vw, 340px) !important;
        max-width: min(84vw, 340px) !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    .cr-home-slider--hero .cr-home-slider__card,
    .cr-home-slider__control,
    .cr-home-slider__dot::before,
    .cr-slider-pdfs .cr-slider-pdfs__card,
    .cr-slider-pdfs .cr-slider-pdfs__cta {
        transition: none !important;
        transform: none !important;
    }
}

/* stylelint-enable no-descending-specificity */

/* UXR24 — recursos: CTA con box sizing real, no botón alto/pesado. */
.cr-slider-pdfs .cr-slider-pdfs__cta {
    box-sizing: border-box;
    min-height: 46px;
    padding: 0 0.78rem 0 1rem;
    white-space: nowrap;
}

.cr-slider-pdfs .cr-slider-pdfs__cta::after {
    flex: 0 0 auto;
}

/* =============================================================
   UXR25 — Rediseño hero (estilo Papr) + header armonizado
   Bloque AUTORITATIVO al final del archivo: gana la cascada sobre
   las declaraciones duplicadas de rondas UXR previas.
   (La deduplicación completa de patterns.css es Fase 4 del roadmap.)
   ============================================================= */

/* ---------- HEADER: tipografía armonizada + versalitas reales ----------
   Especificidad reforzada (.cr-header .cr-header__nav ...) para ganar a las
   reglas UXR previas de igual nombre. */
.cr-header .cr-header__nav a,
.cr-header .cr-header__nav .wp-block-navigation-item__content {
	font-family: var(--wp--preset--font-family--body, "Mulish", sans-serif);
	font-size: 1rem !important;
	font-weight: 600;
	letter-spacing: 0.04em !important;
	text-transform: none !important;
	font-variant-caps: all-small-caps;
	font-feature-settings: "smcp" 1, "c2sc" 1;
}

.cr-header__inner {
	padding-block: 14px;
}

.cr-header__logo img {
	max-height: 46px;
	width: auto;
}

.cr-header__nav {
	gap: clamp(1rem, 1.6vw, 1.75rem);
}

.cr-header__nav a:focus-visible,
.cr-header__nav .wp-block-navigation-item__content:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #89100f);
	outline-offset: 4px;
	border-radius: 2px;
}

.cr-header__nav .current-menu-item > a,
.cr-header__nav [aria-current="page"] {
	color: var(--wp--preset--color--primary, #89100f);
	box-shadow: inset 0 -2px 0 0 var(--wp--preset--color--primary, #89100f);
}

.cr-header__social-link {
	min-width: 44px;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.cr-header__social-link:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #89100f);
	outline-offset: 2px;
	border-radius: 4px;
}

/* ---------- HERO: layout Papr (texto izq / imagen der), imagen 900x537 intacta ----------
   Especificidad reforzada (.cr-home-slider.cr-home-slider--hero) para ganar a las
   reglas UXR previas (incl. las dentro de @media >=1024px). */
@media (min-width: 782px) {
	.cr-home-slider.cr-home-slider--hero .cr-home-slider__card {
		display: grid !important;
		grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr) !important;
		grid-template-areas: "body media" !important;
		align-items: center !important;
		gap: clamp(1.5rem, 4vw, 4rem) !important;
		max-width: 100%;
	}
}

@media (max-width: 781px) {
	.cr-home-slider.cr-home-slider--hero .cr-home-slider__card {
		display: grid !important;
		grid-template-columns: 1fr !important;
		grid-template-areas: "media" "body" !important;
		gap: 1.5rem !important;
	}
}

.cr-home-slider.cr-home-slider--hero .cr-home-slider__body {
	grid-area: body !important;
	overflow: visible;
	text-align: left;
	align-items: flex-start;
	padding-inline: clamp(0.5rem, 2vw, 2rem);
}

.cr-home-slider.cr-home-slider--hero .cr-home-slider__image {
	grid-area: media !important;
	margin: 0;
}

/* La caja YA tiene el ratio 900/537 exacto → cover NO recorta imágenes canónicas (D-131). */
.cr-home-slider--hero .cr-home-slider__image img {
	width: 100%;
	height: auto;
	aspect-ratio: 900 / 537;
	object-fit: cover;
	border-radius: 4px;
	display: block;
}

/* Badge de categoría arriba del bloque de texto. */
.cr-home-slider--hero .cr-home-slider__badge {
	position: static;
	display: inline-block;
	margin-bottom: 0.75rem;
}

/* Autor con avatar circular (estilo Papr). */
.cr-home-slider__byline {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin-bottom: 1rem;
}

.cr-home-slider__byline .avatar,
.cr-home-slider__byline img {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	flex: 0 0 40px;
}

.cr-home-slider__byline .wp-block-post-author__name {
	font-family: var(--wp--preset--font-family--body, "Mulish", sans-serif);
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--wp--preset--color--ink, #1f2024);
}

/* Título grande pero compacto: no se desborda ni se corta. */
.cr-home-slider--hero .cr-home-slider__post-title {
	font-family: var(--wp--preset--font-family--display, "Bodoni Moda", serif);
	font-size: clamp(1.9rem, 1.1rem + 2vw, 3.1rem);
	line-height: 1.04;
	font-weight: 800;
	margin: 0 0 0.5rem;
	max-width: 18ch;
}

.cr-home-slider--hero .cr-home-slider__post-title a {
	color: var(--wp--preset--color--ink, #1f2024);
	text-decoration: none;
}

.cr-home-slider--hero .cr-home-slider__post-title a:hover {
	color: var(--wp--preset--color--primary, #89100f);
}

/* Acciones: CTA sólido vinotinto + enlace secundario. */
.cr-home-slider__actions {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	margin-top: 1.5rem;
	flex-wrap: wrap;
}

.cr-home-slider--hero .cr-home-slider__button .wp-block-read-more,
.cr-home-slider--hero .cr-home-slider__button.wp-block-read-more,
.cr-home-slider--hero a.cr-home-slider__button {
	background-color: var(--wp--preset--color--primary, #89100f);
	color: var(--wp--preset--color--bg, #fff);
	border: 1px solid var(--wp--preset--color--primary, #89100f);
	border-radius: 2px;
	padding: 0.8rem 1.7rem;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	font-family: var(--wp--preset--font-family--body, "Mulish", sans-serif);
	font-weight: 600;
	letter-spacing: 0.02em;
	text-decoration: none;
	transition: background-color 0.2s ease;
}

.cr-home-slider--hero .cr-home-slider__button .wp-block-read-more:hover,
.cr-home-slider--hero a.cr-home-slider__button:hover {
	background-color: var(--wp--preset--color--ink, #1f2024);
	border-color: var(--wp--preset--color--ink, #1f2024);
}

.cr-home-slider__all-link a {
	font-family: var(--wp--preset--font-family--body, "Mulish", sans-serif);
	font-size: 0.9rem;
	font-weight: 600;
	letter-spacing: 0.02em;
	color: var(--wp--preset--color--ink, #1f2024);
	text-decoration: underline;
	text-underline-offset: 4px;
}

.cr-home-slider__all-link a:hover {
	color: var(--wp--preset--color--primary, #89100f);
}

/* Controles/dots dentro de la columna de texto, alineados a la izquierda. */
.cr-home-slider--hero .cr-home-slider__controls {
	justify-content: flex-start;
	margin-top: 1.75rem;
}

/* ---------- Responsive: apilar (imagen arriba, texto abajo) ---------- */
@media (max-width: 781px) {
	.cr-home-slider--hero .cr-home-slider__card {
		grid-template-columns: 1fr;
		grid-template-areas:
			"media"
			"body";
		gap: 1.5rem;
	}

	.cr-home-slider--hero .cr-home-slider__post-title {
		max-width: none;
	}
}

/* =============================================================
   UXR25 Fases 2-4 — single, footer, menús, secciones
   Bloque autoritativo (generado por workflow, aplicado por orquestador).
   Solo tokens var(--wp--preset--*) con fallback. WCAG AA.
   ============================================================= */

/* ---------- single-top: drop cap Bodoni real ---------- */
.cr-single__article-shell .cr-single__content > .wp-block-paragraph:first-of-type::first-letter,
.cr-single__article-shell .wp-block-post-content > p:first-of-type::first-letter {
	font-family: var(--wp--preset--font-family--display, 'Bodoni Moda', 'Bodoni 72', Georgia, serif);
	font-size: 4.6em;
	font-weight: 700;
	font-style: italic;
	font-optical-sizing: auto;
	line-height: 0.82;
	float: left;
	margin: 0.06em 0.1em -0.02em 0;
	color: var(--wp--preset--color--primary, #89100f);
	padding: 0;
	shape-outside: margin-box;
}

@media (max-width: 600px) {
	.cr-single__article-shell .cr-single__content > .wp-block-paragraph:first-of-type::first-letter,
	.cr-single__article-shell .wp-block-post-content > p:first-of-type::first-letter {
		font-size: 3.8em;
		margin: 0.06em 0.08em -0.02em 0;
		line-height: 0.85;
	}
}

/* ---------- single-top: ancho de lectura 68ch ---------- */
.cr-single__article-shell .cr-single__header,
.cr-single__article-shell .cr-single__content,
.cr-single__article-shell .wp-block-post-content {
	max-width: 68ch;
	margin-inline: auto;
	width: 100%;
	box-sizing: border-box;
}

.cr-single__article-shell .cr-single__hero {
	max-width: 100%;
	width: 100%;
	margin-inline: auto;
}

@media (max-width: 600px) {
	.cr-single__article-shell .cr-single__header,
	.cr-single__article-shell .cr-single__content,
	.cr-single__article-shell .wp-block-post-content {
		max-width: 100%;
	}
}

/* ---------- single-top: breadcrumb alineado ---------- */
.cr-single > .cr-breadcrumb,
.cr-single .cr-breadcrumb {
	max-width: 68ch;
	margin-inline: auto;
	width: 100%;
	box-sizing: border-box;
	padding-inline: 0;
}

@media (max-width: 600px) {
	.cr-single > .cr-breadcrumb,
	.cr-single .cr-breadcrumb {
		max-width: 100%;
	}
}

/* ---------- single-top: versalitas reales eyebrow + autor ---------- */
.cr-single__article-shell .cr-single__category,
main.cr-single .cr-single__article-shell .cr-single__category {
	text-transform: none !important;
	font-variant-caps: all-small-caps;
	font-feature-settings: "smcp" 1, "c2sc" 1;
	font-size: 0.88rem;
	letter-spacing: 0.1em;
	font-weight: 700;
	font-family: var(--wp--preset--font-family--body, 'Mulish', sans-serif);
	color: var(--wp--preset--color--primary, #89100f);
}

.cr-single__article-shell .cr-single__category a {
	color: inherit;
	text-decoration: none;
	text-transform: none !important;
}

.cr-single__article-shell .cr-single__author-name {
	text-transform: none;
	font-variant-caps: all-small-caps;
	font-feature-settings: "smcp" 1;
	letter-spacing: 0.04em;
}

/* ---------- single-top: avatar circular + meta ---------- */
.cr-single__article-shell .cr-single__author-avatar img,
.cr-single__header .cr-single__author-avatar img,
.cr-single__header .avatar {
	border-radius: 50%;
	object-fit: cover;
	width: 44px;
	height: 44px;
	flex: 0 0 44px;
}

.cr-single__header .cr-single__meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 0.5rem;
}

/* ---------- single-bottom: separador author-card ---------- */
.cr-single__closing .cr-author-card,
.cr-author-card {
	border-top: 1px solid var(--wp--preset--color--rule, #e5e0db);
	margin-top: var(--wp--preset--spacing--60, 2.5rem);
	padding-top: var(--wp--preset--spacing--50, 2rem);
}

.cr-single__closing {
	max-width: 68ch;
	margin-inline: auto;
}

/* ---------- single-bottom: share focus + tap target ---------- */
.cr-share-buttons__link,
.cr-share-buttons a,
.cr-share-buttons button {
	min-width: 44px;
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
}

.cr-share-buttons__link:focus-visible,
.cr-share-buttons a:focus-visible,
.cr-share-buttons button:focus-visible {
	outline: 2px solid var(--wp--preset--color--primary, #89100f);
	outline-offset: 3px;
	border-radius: 4px;
}

/* ---------- footer: tokenizar color (sin #FFFFFF !important) ---------- */
.cr-footer,
.cr-footer p,
.cr-footer li,
.cr-footer a,
.cr-footer h2,
.cr-footer h3 {
	color: var(--wp--preset--color--on-primary, #fdf6f0);
}

.cr-footer {
	background-color: var(--wp--preset--color--primary, #89100f);
}

/* ---------- footer: tagline confesional ---------- */
.cr-footer__tagline {
	font-family: var(--wp--preset--font-family--display, 'Bodoni Moda', Georgia, serif);
	font-style: italic;
	font-size: 1.05rem;
	letter-spacing: 0.01em;
	color: var(--wp--preset--color--on-primary, #fdf6f0);
	opacity: 0.92;
	margin-top: 0.5rem;
	margin-bottom: 0;
}

/* ---------- footer: contraste copyright AA ---------- */
.cr-footer__copyright,
.cr-footer__bottom,
.cr-footer small {
	color: var(--wp--preset--color--on-primary, #fdf6f0);
	opacity: 0.85;
	font-size: 0.85rem;
}

/* ---------- footer: enlaces y estados ---------- */
.cr-footer a {
	text-decoration: none;
	transition: opacity 0.2s ease;
}

.cr-footer a:hover {
	opacity: 0.75;
	text-decoration: underline;
	text-underline-offset: 3px;
}

.cr-footer a:focus-visible {
	outline: 2px solid var(--wp--preset--color--on-primary, #fdf6f0);
	outline-offset: 3px;
	border-radius: 2px;
}

/* ---------- menus: estado activo ---------- */
.cr-header .cr-header__nav .current-menu-item > a,
.cr-header .cr-header__nav [aria-current="page"] {
	color: var(--wp--preset--color--primary, #89100f);
	box-shadow: inset 0 -2px 0 0 var(--wp--preset--color--primary, #89100f);
}

/* ---------- menus: indicador enlace externo (Oración Matutina) ---------- */
.cr-header .cr-header__nav .cr-nav-external a::after,
.cr-header .cr-header__nav a.cr-nav-external::after {
	content: "\2197";
	display: inline-block;
	margin-inline-start: 0.25em;
	font-size: 0.8em;
	line-height: 1;
	vertical-align: baseline;
}

/* ---------- sections: ritmo vertical ---------- */
.cr-home > .cr-section,
.cr-home > section[class*="cr-section"] {
	margin-block: var(--wp--preset--spacing--70, 3.5rem);
}

/* ---------- sections: tap targets cards/CTA ---------- */
.cr-home .cr-card__button,
.cr-home .cr-section__cta,
.cr-home .wp-block-read-more,
.cr-home .cr-card a.wp-block-read-more {
	min-height: 44px;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

/* ---------- sections: badge separado del borde en mobile ---------- */
@media (max-width: 600px) {
	.cr-card__badge,
	.cr-home-slider__badge,
	.cr-card .cr-card__badge {
		inset-block-start: 0.75rem;
		inset-inline-start: 0.75rem;
	}
}
