/* ============================================================
   PAWM WordPress Plugin — Component Styles
   All rules scoped to .pawm-* — no WP global overrides.
   Colors use WP preset CSS variables with safe fallbacks.
   ============================================================ */

/* ─── Design tokens ──────────────────────────────────────── */
/*
 * Cascada de color:
 *   1. --wp--preset--color--*  → block themes / theme.json (Global Styles)
 *   2. --nv-*                  → Neve customizer (tema clásico activo)
 *   3. hex de último recurso   → cuando ningún tema define la variable
 */
.pawm-list-container,
.pawm-module-container,
.pawm-notice-error {
    --pawm-primary:      var(--wp--preset--color--primary,    var(--nv-primary-accent, #0073aa));
    --pawm-text:         var(--wp--preset--color--contrast,   var(--nv-text-color,     #1e1e1e));
    --pawm-text-muted:   var(--wp--preset--color--contrast-2, #636d77);
    --pawm-bg:           var(--wp--preset--color--base,       var(--nv-site-bg,        #ffffff));
    --pawm-surface:      var(--wp--preset--color--base-2,     var(--nv-light-bg,       #f8fafc));
    --pawm-border:       color-mix(in srgb, var(--pawm-text) 12%, transparent);
    --pawm-highlight:    rgba(255, 235, 59, 0.3);
    --pawm-error:        #dc3545;
    --pawm-error-bg:     #fff5f5;
    --pawm-error-border: #f5c2c7;
    --pawm-error-text:   #6c2b2f;
    --pawm-radius:       6px;
    --pawm-t:            150ms ease;
}

/* ─── Bucket file browser ─────────────────────────────────── */
.pawm-list-container {
    width: 100%;
}

.pawm-list-container ul,
.pawm-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.pawm-content {
    width: 100%;
}

.pawm-list-item > .pawm-item-content {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 4px 0;
}

/* File link */
.pawm-file-link {
    display: flex;
    gap: 7px;
    align-items: center;
    text-decoration: none;
    color: inherit;
    flex: 1;
    min-width: 0;
}

.pawm-file-link:hover {
    color: var(--pawm-primary);
    text-decoration: underline;
}

.pawm-file-link span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.pawm-list-item > .pawm-item-content > a {
    text-decoration: none;
}

.pawm-list-item > .pawm-item-content > a:hover {
    color: var(--pawm-primary);
    text-decoration: underline;
    transition: color var(--pawm-t);
}

.pawm-link {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    border-top: 1px solid var(--pawm-border);
    border-bottom: 1px solid var(--pawm-border);
    padding: 6px 0;
    gap: 12px;
}

/* ─── Accordion ───────────────────────────────────────────── */
.pawm-folder-header {
    cursor: pointer;
    user-select: none;
    border-radius: var(--pawm-radius);
}

.pawm-folder-header:hover {
    background-color: rgba(0, 0, 0, 0.04);
}

.pawm-folder-header:focus-visible {
    outline: 2px solid var(--pawm-primary);
    outline-offset: 2px;
}

.pawm-accordion-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.pawm-chevron {
    transition: transform 0.25s ease;
}

.pawm-list-item.expanded > .pawm-item-content .pawm-chevron {
    transform: rotate(90deg);
}

.pawm-folder-content {
    max-height: 0;
    overflow: hidden;
    padding-left: 20px;
    transition: max-height 0.3s ease-out;
}

.pawm-list-item.expanded > .pawm-folder-content {
    max-height: 10000px;
    transition: max-height 0.5s ease-in;
}

.pawm-folder-name {
    font-weight: 600;
}

.pawm-folder-count {
    font-size: 0.85em;
    opacity: 0.6;
    font-weight: 400;
}

.pawm-folder-icon {
    flex-shrink: 0;
}

/* ─── Empty state ─────────────────────────────────────────── */
.pawm-empty {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 16px;
    color: var(--pawm-text-muted);
    font-size: 0.95em;
    background: var(--pawm-surface);
    border: 1px solid var(--pawm-border);
    border-radius: var(--pawm-radius);
}

.pawm-empty p {
    margin: 0;
}

/* ─── Search bar ──────────────────────────────────────────── */
.pawm-search-container {
    margin-bottom: 20px;
}

.pawm-search-wrapper {
    display: flex;
    align-items: center;
    background: var(--pawm-surface);
    border: 1px solid var(--pawm-border);
    border-radius: var(--pawm-radius);
    padding: 0 12px;
    transition: border-color var(--pawm-t), box-shadow var(--pawm-t);
}

.pawm-search-wrapper:focus-within {
    border-color: var(--pawm-primary);
    box-shadow: 0 0 0 2px color-mix(in srgb, var(--pawm-primary) 18%, transparent);
}

.pawm-search-icon {
    flex-shrink: 0;
    opacity: 0.45;
    color: var(--pawm-text);
}

.pawm-search-input {
    flex: 1;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 11px 10px;
    font-size: 16px;
    outline: none;
    width: 100%;
    color: var(--pawm-text);
}

.pawm-search-input::placeholder {
    color: var(--pawm-text-muted);
    opacity: 1;
}

.pawm-search-clear {
    flex-shrink: 0;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    border-radius: 4px;
    display: none;
    align-items: center;
    justify-content: center;
    opacity: 0.45;
    transition: opacity var(--pawm-t), background var(--pawm-t);
    color: var(--pawm-text);
}

.pawm-search-clear:hover {
    opacity: 1;
    background: rgba(0, 0, 0, 0.08);
}

.pawm-search-clear.visible {
    display: flex;
}

.pawm-search-results {
    margin-top: 8px;
    padding: 7px 12px;
    background: color-mix(in srgb, var(--pawm-primary) 7%, transparent);
    border-left: 3px solid var(--pawm-primary);
    border-radius: 0 var(--pawm-radius) var(--pawm-radius) 0;
    font-size: 0.875em;
}

.pawm-results-count {
    color: var(--pawm-text-muted);
}

/* Search highlight + visibility */
.pawm-list-item.pawm-hidden {
    display: none;
}

.pawm-list-item.pawm-match > .pawm-item-content {
    background-color: var(--pawm-highlight);
    border-radius: var(--pawm-radius);
}

.pawm-list-item.pawm-has-match {
    display: list-item;
}

.pawm-list-item.pawm-has-match.expanded > .pawm-folder-content {
    max-height: 10000px;
}

/* ─── Module container (all [Pawm origen=...] views) ─────── */
.pawm-module-container {
    width: 100%;
}

.pawm-module-content {
    /* overflow handled by wp-block-table wrapper on each table */
}

/* ─── Section — details/summary accordion ────────────────── */
.pawm-section {
    border: 1px solid var(--pawm-border);
    border-radius: var(--pawm-radius);
    margin-bottom: 10px;
    overflow: hidden;
}

.pawm-section[open] {
    border-color: color-mix(in srgb, var(--pawm-primary) 40%, transparent);
}

.pawm-section-title {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 11px 16px;
    font-weight: 600;
    font-size: 1em;
    cursor: pointer;
    list-style: none;
    background: var(--pawm-surface);
    color: var(--pawm-text);
    user-select: none;
    transition: background var(--pawm-t);
    margin: 0;
}

.pawm-section-title::-webkit-details-marker { display: none; }
.pawm-section-title::marker               { display: none; content: ""; }

.pawm-section-title::before {
    content: "";
    display: inline-block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 5px 0 5px 7px;
    border-color: transparent transparent transparent var(--pawm-text-muted);
    flex-shrink: 0;
    transition: transform 0.2s ease;
}

.pawm-section[open] > .pawm-section-title::before {
    transform: rotate(90deg);
}

.pawm-section-title:hover {
    background: rgba(0, 0, 0, 0.04);
}

.pawm-section-title:focus-visible {
    outline: 2px solid var(--pawm-primary);
    outline-offset: -2px;
}

.pawm-section-body {
    padding: 0 16px 16px;
}

/* ─── Subsection ──────────────────────────────────────────── */
.pawm-subsection {
    margin-top: 16px;
}

.pawm-subsection-title {
    font-size: 0.78em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--pawm-text-muted);
    margin: 0 0 8px;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--pawm-border);
}

/* ─── Neutralizar estilos de wp-block-table que chocan ───── */
/* WP pone border: 1px solid (4 lados) en td/th — cancelamos
   los lados y dejamos sólo el inferior que ya define pawm-table. */
.wp-block-table .pawm-table thead {
    border-bottom: none;          /* WP pone 3px solid — lo quitamos */
}

.wp-block-table .pawm-table th,
.wp-block-table .pawm-table td {
    border-top: none;
    border-left: none;
    border-right: none;
    border-color: var(--pawm-border);
}

/* ─── Table ───────────────────────────────────────────────── */
.pawm-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9em;
    min-width: 360px;
}

.pawm-table th {
    text-align: left;
    padding: 9px 12px;
    font-weight: 700;
    font-size: 0.75em;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--pawm-text-muted);
    border-bottom: 2px solid var(--pawm-border);
    white-space: nowrap;
    background: var(--pawm-surface);
}

.pawm-table td {
    padding: 9px 12px;
    border-bottom: 1px solid var(--pawm-border);
    vertical-align: middle;
    color: var(--pawm-text);
}

.pawm-row:hover td {
    background: var(--pawm-surface);
}

.pawm-empty-cell {
    text-align: center !important;
    color: var(--pawm-text-muted) !important;
    font-style: italic;
    padding: 20px 12px !important;
}

/* ─── Download button ─────────────────────────────────────── */
.pawm-btn-download {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 6px 11px;
    background: var(--pawm-primary);
    color: #fff !important;
    border-radius: var(--pawm-radius);
    text-decoration: none !important;
    font-size: 0.82em;
    font-weight: 600;
    white-space: nowrap;
    min-height: 34px;
    line-height: 1;
    transition: opacity var(--pawm-t), box-shadow var(--pawm-t);
    border: none;
    cursor: pointer;
}

.pawm-btn-download:hover {
    opacity: 0.85;
    color: #fff !important;
    text-decoration: none !important;
}

.pawm-btn-download:focus-visible {
    outline: 2px solid var(--pawm-primary);
    outline-offset: 2px;
    box-shadow: 0 0 0 4px color-mix(in srgb, var(--pawm-primary) 22%, transparent);
    opacity: 1;
}

.pawm-btn-label {
    line-height: 1;
}

/* ─── Error notice ────────────────────────────────────────── */
.pawm-notice-error {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    border: 1px solid var(--pawm-error-border);
    border-left: 4px solid var(--pawm-error);
    background: var(--pawm-error-bg);
    border-radius: var(--pawm-radius);
    font-size: 0.95em;
}

.pawm-notice-error svg {
    flex-shrink: 0;
    margin-top: 1px;
    color: var(--pawm-error);
}

.pawm-notice-error strong {
    display: block;
    color: var(--pawm-error-text);
}

.pawm-notice-error p {
    margin: 4px 0 0;
    font-size: 0.9em;
    color: var(--pawm-error-text);
}

/* ─── Tabla Ley — Lista de períodos ──────────────────────── */
.pawm-tabla-ley-heading {
    font-size: 1em;
    font-weight: 700;
    color: var(--pawm-text);
    margin: 0 0 14px;
    padding: 0;
}

.pawm-tabla-ley-lista {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--pawm-border);
    border-radius: var(--pawm-radius);
    overflow: hidden;
}

.pawm-tabla-ley-periodo {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px;
    text-decoration: none !important;
    color: var(--pawm-text) !important;
    background: var(--pawm-bg);
    border-bottom: 1px solid var(--pawm-border);
    transition: background var(--pawm-t), padding-left 200ms ease;
    min-height: 52px;
}

.pawm-tabla-ley-periodo:last-child {
    border-bottom: none;
}

.pawm-tabla-ley-periodo:hover {
    background: var(--pawm-surface);
    color: var(--pawm-primary) !important;
    padding-left: 24px;
}

.pawm-tabla-ley-periodo:focus-visible {
    outline: 2px solid var(--pawm-primary);
    outline-offset: -2px;
}

.pawm-tabla-ley-periodo-label {
    font-size: 0.97em;
    font-weight: 500;
    line-height: 1.4;
}

.pawm-tabla-ley-periodo-icon {
    font-size: 1.4em;
    color: var(--pawm-text-muted);
    flex-shrink: 0;
    line-height: 1;
    transition: transform 200ms ease, color var(--pawm-t);
}

.pawm-tabla-ley-periodo:hover .pawm-tabla-ley-periodo-icon {
    color: var(--pawm-primary);
    transform: translateX(3px);
}

/* ─── Tabla Ley — Detalle ─────────────────────────────────── */
.pawm-tabla-ley-back {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 16px;
    font-size: 0.875em;
    font-weight: 500;
    color: var(--pawm-primary) !important;
    text-decoration: none !important;
    transition: color var(--pawm-t);
}

.pawm-tabla-ley-back:hover {
    color: var(--pawm-text) !important;
}

.pawm-tabla-ley-item {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    padding: 12px 0;
    border-bottom: 1px solid var(--pawm-border);
}

.pawm-tabla-ley-item:last-child {
    border-bottom: none;
}

.pawm-tabla-ley-item-titulo {
    flex: 1;
    min-width: 0;
    font-size: 0.92em;
    line-height: 1.55;
    color: var(--pawm-text);
    padding-top: 5px;
}

.pawm-tabla-ley-item-urls {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    flex-shrink: 0;
}

@media (max-width: 600px) {
    .pawm-tabla-ley-item {
        flex-direction: column;
        gap: 8px;
    }

    .pawm-tabla-ley-item-titulo {
        padding-top: 0;
    }
}

/* ─── Reduced motion ──────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .pawm-chevron,
    .pawm-folder-content,
    .pawm-search-wrapper,
    .pawm-search-clear,
    .pawm-section-title,
    .pawm-section-title::before,
    .pawm-btn-download,
    .pawm-tabla-ley-periodo,
    .pawm-tabla-ley-periodo-icon,
    .pawm-tabla-ley-back {
        transition: none;
    }

    .pawm-tabla-ley-periodo:hover {
        padding-left: 20px;
    }

    .pawm-tabla-ley-periodo:hover .pawm-tabla-ley-periodo-icon {
        transform: none;
    }
}

/* ─── Personas — Grid de tarjetas (gabinete / regidores) ───── */
.pawm-personas-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 20px;
    margin-top: 8px;
}

.pawm-persona-card {
    display: flex;
    flex-direction: column;
    text-decoration: none !important;
    color: var(--pawm-text) !important;
    background: var(--pawm-bg);
    border: 1px solid var(--pawm-border);
    border-radius: 16px;
    overflow: hidden;
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
    cursor: pointer;
}

.pawm-persona-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10);
    border-color: var(--pawm-primary);
    color: var(--pawm-text) !important;
    text-decoration: none !important;
}

.pawm-persona-card:focus-visible {
    outline: 3px solid var(--pawm-primary);
    outline-offset: 2px;
    border-color: var(--pawm-primary);
}

/* Foto */
.pawm-persona-card-foto-wrap {
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background: var(--pawm-surface);
}

.pawm-persona-card-foto {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
    transition: transform 300ms ease;
}

.pawm-persona-card:hover .pawm-persona-card-foto {
    transform: scale(1.04);
}

.pawm-persona-foto-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    color: var(--pawm-text-muted);
}

.pawm-persona-foto-placeholder svg {
    width: 60%;
    height: 60%;
}

/* Info dentro de tarjeta */
.pawm-persona-card-info {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 14px 16px 10px;
    flex: 1;
}

.pawm-persona-card-nombre {
    font-size: 0.97em;
    font-weight: 700;
    color: var(--pawm-text);
    line-height: 1.3;
    margin: 0;
}

.pawm-persona-card-cargo {
    font-size: 0.82em;
    color: var(--pawm-primary);
    font-weight: 500;
    line-height: 1.3;
}

.pawm-persona-card-area {
    font-size: 0.78em;
    color: var(--pawm-text-muted);
    line-height: 1.3;
}

/* CTA al fondo de tarjeta */
.pawm-persona-card-cta {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin: 0 16px 14px;
    font-size: 0.78em;
    font-weight: 600;
    color: var(--pawm-primary);
    opacity: 0;
    transform: translateX(-4px);
    transition: opacity 200ms ease, transform 200ms ease;
}

.pawm-persona-card:hover .pawm-persona-card-cta {
    opacity: 1;
    transform: translateX(0);
}

/* ─── Persona — Perfil detalle (presidente / detallePersonal) ─ */
.pawm-persona-perfil {
    display: grid;
    grid-template-columns: clamp(220px, 33%, 320px) 1fr;
    gap: 40px 48px;
    align-items: start;
}

/* Columna foto */
.pawm-persona-perfil-foto-col {
    display: flex;
    flex-direction: column;
    gap: 20px;
    position: sticky;
    top: 20px;
}

.pawm-persona-perfil-foto-wrap {
    border-radius: 16px;
    overflow: hidden;
    background: var(--pawm-surface);
    border: 1px solid var(--pawm-border);
    aspect-ratio: 3 / 4;
}

.pawm-persona-perfil-foto-wrap--placeholder {
    aspect-ratio: 3 / 4;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--pawm-text-muted);
}

.pawm-persona-perfil-foto-wrap--placeholder svg {
    width: 60%;
    height: 60%;
}

.pawm-persona-perfil-foto {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
}

/* Contacto en columna foto (mobile hidden, visible en foto col) */
.pawm-persona-perfil-contacto {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.pawm-persona-perfil-contacto--inline {
    display: none; /* visible solo en mobile */
    flex-direction: column;
    gap: 10px;
    margin-top: 20px;
}

.pawm-persona-perfil-contacto-item {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.88em;
    color: var(--pawm-text-muted) !important;
    text-decoration: none !important;
    transition: color 150ms ease;
}

.pawm-persona-perfil-contacto-item:hover {
    color: var(--pawm-primary) !important;
}

.pawm-persona-perfil-contacto-item svg {
    flex-shrink: 0;
    color: var(--pawm-primary);
}

/* Columna info */
.pawm-persona-perfil-info {
    padding-top: 8px;
}

.pawm-persona-perfil-puesto {
    font-size: 0.82em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--pawm-primary);
    margin: 0 0 8px;
}

.pawm-persona-perfil-nombre {
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--pawm-text);
    margin: 0 0 16px;
}

.pawm-persona-perfil-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 24px;
}

.pawm-persona-perfil-badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 0.8em;
    font-weight: 600;
    line-height: 1.4;
}

.pawm-persona-perfil-badge--cargo {
    background: color-mix(in srgb, var(--pawm-primary) 10%, transparent);
    color: var(--pawm-primary);
    border: 1px solid color-mix(in srgb, var(--pawm-primary) 22%, transparent);
}

.pawm-persona-perfil-badge--area {
    background: var(--pawm-surface);
    color: var(--pawm-text-muted);
    border: 1px solid var(--pawm-border);
}

.pawm-persona-perfil-bio {
    font-size: 0.95em;
    line-height: 1.7;
    color: var(--pawm-text);
    border-top: 1px solid var(--pawm-border);
    padding-top: 20px;
    margin-top: 4px;
}

.pawm-persona-perfil-bio > *:first-child { margin-top: 0; }
.pawm-persona-perfil-bio > *:last-child  { margin-bottom: 0; }

/* ─── Responsive personas ─────────────────────────────────── */
@media (max-width: 768px) {
    .pawm-personas-grid {
        grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
        gap: 14px;
    }

    .pawm-persona-perfil {
        grid-template-columns: 1fr;
        gap: 24px;
    }

    .pawm-persona-perfil-foto-col {
        position: static;
        flex-direction: row;
        align-items: flex-start;
        gap: 16px;
    }

    .pawm-persona-perfil-foto-wrap,
    .pawm-persona-perfil-foto-wrap--placeholder {
        width: 120px;
        flex-shrink: 0;
        aspect-ratio: 1 / 1;
    }

    /* En mobile: contacto sube junto a la foto, lo de foto-col se oculta */
    .pawm-persona-perfil-contacto:not(.pawm-persona-perfil-contacto--inline) {
        flex: 1;
        justify-content: center;
    }

    .pawm-persona-perfil-info {
        padding-top: 0;
    }

    .pawm-persona-perfil-contacto--inline {
        display: flex;
    }
}

@media (max-width: 480px) {
    .pawm-personas-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }

    .pawm-persona-perfil-foto-col {
        flex-direction: column;
        align-items: center;
        text-align: center;
    }

    .pawm-persona-perfil-foto-wrap,
    .pawm-persona-perfil-foto-wrap--placeholder {
        width: 100%;
        max-width: 200px;
        aspect-ratio: 1 / 1;
    }

    .pawm-persona-perfil-badges {
        justify-content: center;
    }

    .pawm-persona-perfil-nombre {
        text-align: center;
    }

    .pawm-persona-perfil-puesto {
        text-align: center;
    }
}

/* ─── Noticias — Grid de tarjetas ──────────────────────────── */
.pawm-news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
    margin-top: 8px;
}

.pawm-news-card {
    display: flex;
    flex-direction: column;
    position: relative;
    background: var(--pawm-bg);
    border: 1px solid var(--pawm-border);
    border-radius: 16px;
    overflow: hidden;
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
    margin: 0;
    padding: 0;
}

.pawm-news-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.10);
    border-color: var(--pawm-primary);
}

.pawm-news-img-link {
    display: block;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: var(--pawm-surface);
}

.pawm-news-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 300ms ease;
}

.pawm-news-card:hover .pawm-news-img {
    transform: scale(1.04);
}

.pawm-news-date {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--pawm-bg);
    border-radius: 8px;
    padding: 6px 10px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12);
    font-size: 0.75em;
    line-height: 1.2;
    color: var(--pawm-text-muted);
    min-width: 36px;
    text-align: center;
}

.pawm-news-date span:first-child {
    font-size: 1.4em;
    font-weight: 700;
    color: var(--pawm-text);
    line-height: 1;
}

.pawm-news-date span:nth-child(2) {
    font-weight: 600;
    color: var(--pawm-primary);
    text-transform: uppercase;
    font-size: 0.9em;
}

.pawm-news-body {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 14px 16px 16px;
    flex: 1;
}

.pawm-news-title {
    font-size: 1.05em;
    font-weight: 700;
    line-height: 1.3;
    margin: 0;
}

.pawm-news-title a {
    color: var(--pawm-text) !important;
    text-decoration: none !important;
}

.pawm-news-title a:hover {
    color: var(--pawm-primary) !important;
}

.pawm-news-excerpt {
    font-size: 0.9em;
    color: var(--pawm-text-muted);
    line-height: 1.5;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.pawm-btn-mas {
    margin-top: auto;
    align-self: flex-start;
    font-size: 0.85em;
    font-weight: 600;
    color: var(--pawm-primary) !important;
    text-decoration: none !important;
}

.pawm-btn-mas:hover {
    text-decoration: underline !important;
}

/* ─── Detalle de noticia ────────────────────────────────────── */
.pawm-noticia-article {
    width: 100%;
}

@media (min-width: 1024px) {
    .pawm-noticia-article,
    .pawm-noticias .pawm-news-grid {
        width: 80%;
        margin-left: auto;
        margin-right: auto;
    }
}

.pawm-noticia-header {
    border-bottom: 2px solid var(--pawm-border);
    padding-bottom: 20px;
    margin-bottom: 28px;
}

.pawm-noticia-titulo {
    font-size: clamp(1.75rem, 4vw, 2.6rem);
    font-weight: 800;
    line-height: 1.15;
    letter-spacing: -0.025em;
    margin: 0 0 14px;
    color: var(--pawm-text);
}

.pawm-noticia-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px 16px;
    font-size: 0.85em;
    color: var(--pawm-text-muted);
}

.pawm-noticia-area {
    display: inline-flex;
    align-items: center;
    background: color-mix(in srgb, var(--pawm-primary) 12%, transparent);
    color: var(--pawm-primary);
    font-weight: 600;
    font-size: 0.8em;
    padding: 3px 10px;
    border-radius: 20px;
    letter-spacing: 0.02em;
    text-transform: uppercase;
}

.pawm-noticia-fecha {
    font-size: 0.88em;
    color: var(--pawm-text-muted);
}

.pawm-noticia-portada {
    margin: 0 0 32px;
    border-radius: 20px;
    overflow: hidden;
    aspect-ratio: 16 / 9;
    background: var(--pawm-surface);
}

.pawm-noticia-portada img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pawm-noticia-content {
    display: flex;
    flex-direction: column;
    gap: 20px;
    font-size: 1.05em;
    line-height: 1.75;
    color: var(--pawm-text);
    border-top: 1px solid var(--pawm-border);
    padding-top: 28px;
    margin-top: 4px;
}

.pawm-noticia-content p {
    margin: 0;
}

.pawm-noticia-figura {
    margin: 8px auto;
    text-align: center;
}

.pawm-noticia-img {
    max-width: 100%;
    height: auto;
    border-radius: 14px;
    display: block;
    margin: 0 auto;
}

.pawm-noticia-archivo {
    display: flex;
    align-items: center;
    gap: 10px;
    background: var(--pawm-surface);
    border: 1px solid var(--pawm-border);
    border-radius: 10px;
    padding: 12px 16px;
}

.pawm-archivo-nombre {
    font-size: 0.9em;
    color: var(--pawm-text-muted);
}

@media (max-width: 480px) {
    .pawm-noticia-titulo {
        letter-spacing: -0.01em;
    }
}

@media (max-width: 480px) {
    .pawm-news-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .pawm-noticia-titulo {
        font-size: 1.3em;
    }
}

/* ─── Reduced motion — personas ──────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .pawm-persona-card,
    .pawm-persona-card-foto,
    .pawm-persona-card-cta,
    .pawm-persona-perfil-contacto-item,
    .pawm-news-card,
    .pawm-news-img {
        transition: none;
    }

    .pawm-persona-card:hover {
        transform: none;
    }

    .pawm-persona-card:hover .pawm-persona-card-foto {
        transform: none;
    }

    .pawm-persona-card:hover .pawm-persona-card-cta {
        opacity: 1;
        transform: none;
    }

    .pawm-news-card:hover {
        transform: none;
    }

    .pawm-news-card:hover .pawm-news-img {
        transform: none;
    }
}

/* ─── Lightbox — imágenes de artículo ──────────────────────── */
#pawm-lightbox {
    display: flex;
    position: fixed;
    inset: 0;
    z-index: 99999;
    background: rgba(0, 0, 0, 0.88);
    align-items: center;
    justify-content: center;
    padding: 20px;
    cursor: zoom-out;
    /* estado oculto — exit: 180ms ease-in */
    opacity: 0;
    visibility: hidden;
    transition: opacity 180ms ease-in, visibility 0s linear 180ms;
}

#pawm-lightbox.is-open {
    /* estado visible — enter: 260ms ease-out */
    opacity: 1;
    visibility: visible;
    transition: opacity 260ms ease-out, visibility 0s linear 0s;
}

.pawm-lightbox-img {
    max-width: 100%;
    max-height: 90vh;
    object-fit: contain;
    border-radius: 10px;
    display: block;
    cursor: default;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.6);
    /* exit */
    transform: scale(0.9);
    opacity: 0;
    transition: transform 180ms ease-in, opacity 180ms ease-in;
}

#pawm-lightbox.is-open .pawm-lightbox-img {
    /* enter: spring-like overshoot sutil */
    transform: scale(1);
    opacity: 1;
    transition: transform 300ms cubic-bezier(0.34, 1.2, 0.64, 1), opacity 260ms ease-out;
}

.pawm-lightbox-close {
    position: absolute;
    top: 16px;
    right: 20px;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.2);
    color: #fff;
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    border-radius: 50%;
    padding: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    line-height: 1;
    /* entra junto con overlay */
    opacity: 0;
    transform: scale(0.8) rotate(-45deg);
    transition: opacity 260ms ease-out 80ms, transform 260ms ease-out 80ms, background 180ms ease;
}

.pawm-lightbox-close svg {
    display: block;
    flex-shrink: 0;
}

#pawm-lightbox.is-open .pawm-lightbox-close {
    opacity: 1;
    transform: scale(1) rotate(0deg);
}

.pawm-lightbox-close:hover,
.pawm-lightbox-close:focus-visible {
    background: rgba(255, 255, 255, 0.25);
    transform: scale(1.1) rotate(0deg);
    outline: 2px solid rgba(255, 255, 255, 0.5);
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    #pawm-lightbox,
    #pawm-lightbox.is-open,
    .pawm-lightbox-img,
    #pawm-lightbox.is-open .pawm-lightbox-img,
    .pawm-lightbox-close,
    #pawm-lightbox.is-open .pawm-lightbox-close {
        transition: none;
        transform: none;
        opacity: 1;
    }

    #pawm-lightbox {
        opacity: 0;
        visibility: hidden;
    }

    #pawm-lightbox.is-open {
        opacity: 1;
        visibility: visible;
    }
}

/* ===== Botón "Ver más" (debajo del grid del shortcode) ===== */
.pawm-news-vermas-wrap {
    display: flex;
    justify-content: center;
    margin-top: 32px;
}
.pawm-btn-vermas {
    display: inline-block;
    padding: 12px 28px;
    background: var(--wp--preset--color--primary, #1f3a5f);
    color: #fff;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 600;
    transition: background .2s ease, transform .2s ease;
}
.pawm-btn-vermas:hover {
    background: var(--wp--preset--color--primary-hover, #16294a);
    transform: translateY(-2px);
}

/* ===== Página /noticias ===== */
.pawm-noticias-listado {
    padding-bottom: 72px;
}
.pawm-noticias-listado .pawm-listado-header {
    text-align: center;
    margin-bottom: 32px;
}

/* Paginador */
.pawm-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 6px;
    margin-top: 56px;
    flex-wrap: wrap;
}
.pawm-pagination__link {
    display: inline-flex;
    min-width: 44px;
    height: 44px;
    padding: 0 14px;
    align-items: center;
    justify-content: center;
    border: 1.5px solid #d0d7de;
    border-radius: 8px;
    color: inherit;
    text-decoration: none;
    font-weight: 500;
    font-size: 0.9375rem;
    line-height: 1;
    transition: background .15s ease, border-color .15s ease, box-shadow .15s ease;
    user-select: none;
}
.pawm-pagination__link:hover {
    background: #f0f4f8;
    border-color: #8b98a8;
    text-decoration: none;
}
.pawm-pagination__link:focus-visible {
    outline: 3px solid var(--wp--preset--color--primary, #1f3a5f);
    outline-offset: 2px;
}
.pawm-pagination__active {
    background: var(--wp--preset--color--primary, #1f3a5f);
    color: #fff !important;
    border-color: transparent;
    pointer-events: none;
    box-shadow: 0 2px 6px rgba(31, 58, 95, .35);
}
.pawm-pagination__disabled {
    color: #b0b9c4;
    pointer-events: none;
    background: #f6f8fa;
    border-color: #e4e8ec;
}
.pawm-pagination__arrow {
    font-size: 1.25rem;
    padding: 0 12px;
}
.pawm-pagination__ellipsis {
    display: inline-flex;
    min-width: 44px;
    height: 44px;
    align-items: center;
    justify-content: center;
    color: #8b98a8;
    font-size: 1rem;
    user-select: none;
}
}