/* ==========================================================
   LISTING LAYOUT
   Usado por paragraph--layout-listado.html.twig
   - /actualidad/noticias
   - /actualidad/eventos
   - /actualidad/bandos
========================================================== */

.listing-layout {
  background: var(--color-bg);
}

.listing-layout__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}

.listing-layout--no-sidebar .listing-layout__grid {
  grid-template-columns: minmax(0, 1fr);
}

.listing-layout__main {
  min-width: 0;
}

.listing-layout__sidebar {
  position: sticky;
  top: 7rem;
  align-self: start;
  display: grid;
  gap: 1rem;
  min-width: 0;
}

.listing-layout__section-header {
  margin-bottom: 1.25rem;
}

.listing-layout__section-title {
  margin: 0;
  color: var(--color-primary-dark);
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1.15;
  font-weight: 760;
  letter-spacing: -.035em;
}

.listing-layout__featured {
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.listing-layout__list,
.listing-layout__featured {
  min-width: 0;
}

.listing-layout__list .view-content,
.listing-layout--evento .view-content,
.listing-layout--bando .view-content {
  display: grid;
  gap: 1rem;
}

.listing-layout__sidebar-extra {
  display: grid;
  gap: 1rem;
}

/* Sidebar + filtros */

.listing-sidebar-card {
  background: #f2f2f2;
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--shadow-sm);
}

.listing-sidebar-card__title {
  margin: 0 0 1.25rem;
  color: var(--color-primary-dark);
  font-size: 1.25rem;
  line-height: 1.15;
  font-weight: 650;
  letter-spacing: -.02em;
}

.listing-sidebar-card .views-exposed-form,
.listing-sidebar-card .form--inline,
.listing-sidebar-card .fieldset-wrapper {
  display: grid;
  gap: 1rem;
}

.listing-sidebar-card .form--inline {
  float: none;
}

.listing-sidebar-card fieldset {
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

.listing-sidebar-card legend {
  margin: 0 0 .75rem;
  padding: 0;
}

.listing-sidebar-card .fieldset-legend {
  color: var(--color-primary-dark);
  font-size: .9rem;
  line-height: 1.2;
  font-weight: 560;
}

.listing-sidebar-card .bef-toggle {
  display: none;
}

.listing-sidebar-card .form-checkboxes,
.listing-sidebar-card .bef-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.listing-sidebar-card .form-type-checkbox {
  position: relative;
  margin: 0;
}

.listing-sidebar-card .form-type-checkbox input[type="checkbox"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.listing-sidebar-card .form-type-checkbox label.option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: .65rem .9rem;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-primary-dark);
  font-size: .88rem;
  line-height: 1.15;
  font-weight: 520;
  cursor: pointer;
  user-select: none;
  transition:
    background .18s ease,
    border-color .18s ease,
    color .18s ease,
    transform .18s ease;
}

.listing-sidebar-card .form-type-checkbox label.option:hover {
  background: #f7f7f7;
  border-color: rgba(17,53,85,.22);
}

.listing-sidebar-card .form-type-checkbox input[type="checkbox"]:checked + label.option {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

.listing-sidebar-card .form-type-checkbox input[type="checkbox"]:focus-visible + label.option {
  outline: 3px solid #ffbf47;
  outline-offset: 3px;
}

.listing-sidebar-card .form-actions {
  margin: .25rem 0 0;
}

.listing-sidebar-card .form-submit {
  width: 100%;
  min-height: 52px;
  border: 0;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: #fff;
  font-size: .95rem;
  font-weight: 620;
  cursor: pointer;
  transition:
    background .18s ease,
    transform .18s ease;
}

.listing-sidebar-card .form-submit:hover {
  background: var(--color-primary-dark);
  transform: translateY(-1px);
}

/* ==========================================================
   ACTUALIDAD: NOTICIAS
========================================================== */

.news-featured .view-content {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.news-featured-card {
  height: 100%;
}

.news-featured-card__link {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  color: inherit;
  text-decoration: none;
  transition:
    transform .2s ease,
    box-shadow .2s ease,
    border-color .2s ease;
}

.news-featured-card__link:hover {
  transform: translateY(-3px);
  border-color: rgba(17,53,85,.18);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
}

.news-featured-card__media {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--color-primary-soft);
}

.news-featured-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.news-featured-card__link:hover .news-featured-card__media img {
  transform: scale(1.03);
}

.news-featured-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.5rem;
  background: #f2f6fa;
}

.news-featured-card__category {
  margin: 0 0 .85rem;
  color: var(--color-primary);
  font-size: .74rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.news-featured-card__title {
  margin: 0 0 1rem;
  color: var(--color-primary-dark);
  font-size: clamp(1.2rem, 1.5vw, 1.45rem);
  line-height: 1.25;
  font-weight: 600;
  letter-spacing: -.015em;
}

.news-featured-card__link:hover .news-featured-card__title {
  text-decoration: underline;
  text-decoration-thickness: var(--link-underline-thickness);
  text-underline-offset: var(--link-underline-offset);
}

.news-featured-card__summary {
  margin: 0 0 1.5rem;
  color: var(--color-muted);
  font-size: .96rem;
  line-height: 1.7;
  font-weight: 420;
}

.news-featured-card__date {
  margin-top: auto;
  color: var(--color-muted);
  font-size: .82rem;
  line-height: 1.2;
  font-weight: 520;
}

.news-list-item {
  background: transparent;
}

.news-list-item__link {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr) 24px;
  align-items: stretch;
  gap: 1.5rem;
  min-height: 190px;
  padding: 0 1rem 0 0;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  color: inherit;
  text-decoration: none;
  transition:
    transform .18s ease,
    border-color .18s ease,
    box-shadow .18s ease;
}

.news-list-item__link:hover {
  transform: translateY(-2px);
  border-color: rgba(17,53,85,.18);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
}

.news-list-item__media {
  height: 100%;
  min-height: 190px;
  overflow: hidden;
  border-radius: 0;
  background: var(--color-primary-soft);
}

.news-list-item__media,
.news-list-item__media .field,
.news-list-item__media .field__item,
.news-list-item__media article,
.news-list-item__media .media,
.news-list-item__media picture {
  width: 100%;
  height: 100%;
  display: block;
}

.news-list-item__media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  transition: transform .35s ease;
}

.news-list-item__link:hover .news-list-item__media img {
  transform: scale(1.03);
}

.news-list-item__content {
  min-width: 0;
  padding-block: 1.25rem;
}

.news-list-item__meta {
  display: flex;
  align-items: center;
  gap: .85rem;
  margin-bottom: .85rem;
  flex-wrap: wrap;
}

.news-list-item__category {
  color: var(--color-primary);
  font-size: .72rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.news-list-item__meta time {
  color: var(--color-muted);
  font-size: .8rem;
  line-height: 1;
  font-weight: 520;
}

.news-list-item__title {
  margin: 0 0 .9rem;
  color: var(--color-primary-dark);
  font-size: clamp(1.15rem, 1.4vw, 1.35rem);
  line-height: 1.3;
  font-weight: 600;
  letter-spacing: -.015em;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-list-item__link,
.news-list-item__link:hover,
.news-list-item__link:focus,
.news-list-item__link:active {
  color: inherit;
  text-decoration: none;
}

.news-list-item__link:hover .news-list-item__title {
  text-decoration: underline;
  text-decoration-thickness: var(--link-underline-thickness);
  text-underline-offset: var(--link-underline-offset);
  text-decoration-skip-ink: auto;
}

.news-list-item__meta,
.news-list-item__meta *,
.news-list-item__summary,
.news-list-item__arrow,
.news-list-item__arrow * {
  text-decoration: none !important;
}

.news-list-item__summary {
  margin: 0;
  color: var(--color-muted);
  font-size: .96rem;
  line-height: 1.7;
  font-weight: 420;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.news-list-item__date {
  align-self: center;
  color: var(--color-muted);
  font-size: .82rem;
  line-height: 1.2;
  font-weight: 520;
  white-space: nowrap;
}

.news-list-item__arrow {
  align-self: center;
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  color: var(--color-primary);
  font-size: .9rem;
  transition:
    transform .18s ease,
    color .18s ease;
}

.news-list-item__link:hover .news-list-item__arrow {
  transform: translateX(3px);
  color: var(--color-primary-dark);
}

@media (max-width: 1100px) {
  .listing-layout__grid {
    grid-template-columns: 1fr;
  }

  .listing-layout__sidebar {
    position: static;
    order: 2;
  }

  .news-featured .view-content {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .news-list-item__link {
    grid-template-columns: 1fr;
    gap: 0;
    min-height: auto;
    padding: 0;
    overflow: hidden;
  }

  .news-list-item__media {
    width: 100%;
    min-height: 0;
    aspect-ratio: 16 / 9;
    border-radius: 0;
  }

  .news-list-item__content {
    padding: 1rem;
  }

  .news-list-item__date {
    padding: 0 1rem 1rem;
    align-self: start;
  }

  .news-list-item__arrow {
    display: none;
  }

  .news-featured-card__body {
    padding: 1rem;
  }
}

/* ==========================================================
   LISTING LAYOUT + FILTROS
========================================================== */

.listing-layout,
.listing-layout * {
  box-sizing: border-box;
}

.listing-layout__main,
.listing-layout__list,
.listing-layout .view,
.listing-layout .view-content,
.listing-layout .views-row {
  min-width: 0;
}

.listing-layout__section-header {
  margin-bottom: 1.25rem;
}

.listing-layout__section-title {
  margin: 0;
  color: var(--color-primary-dark);
  font-size: clamp(1.45rem, 2.2vw, 2rem);
  line-height: 1.15;
  font-weight: 760;
  letter-spacing: -.035em;
}

.listing-layout__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}

.listing-layout__main {
  min-width: 0;
}

.listing-layout__sidebar {
  position: static;
  display: grid;
  gap: 1rem;
  align-self: start;
}

.listing-layout__filters-slot .view-filters,
.listing-layout__sidebar-extra > .field__items > .field__item,
.listing-layout__sidebar-extra .paragraph {
  /*background: #f2f2f2;*/
  border-radius: var(--radius-lg);
  /*padding: 1.5rem;*/
  box-shadow: var(--shadow-sm);
}

/*    PARAGRAPH BLOQUE DESTACADO EN SIDEBAR  */

.listing-layout__sidebar .vt-highlight,
.layout-sidebar-second .vt-highlight,
.layout-sidebar-first .vt-highlight,
.sidebar .vt-highlight {
  padding-block: 0;
}

.listing-layout__sidebar .vt-highlight__box,
.layout-sidebar-second .vt-highlight__box,
.layout-sidebar-first .vt-highlight__box {
  padding: 1.5rem;
  gap: 2rem;
}

.listing-layout__sidebar .vt-highlight__title,
.layout-sidebar-second .vt-highlight__title,
.layout-sidebar-first .vt-highlight__title {
  font-size: clamp(1.85rem, 2.4vw, 2.4rem);
}

.listing-layout__sidebar .vt-highlight__icon,
.layout-sidebar-second .vt-highlight__icon,
.layout-sidebar-first .vt-highlight__icon {
  width: auto;
  font-size: 4rem;
}

.listing-layout__sidebar .vt-highlight__links,
.layout-sidebar-second .vt-highlight__links,
.layout-sidebar-first .vt-highlight__links {
  flex-direction: column;
}

.listing-layout__sidebar .vt-highlight-button,
.layout-sidebar-second .vt-highlight-button,
.layout-sidebar-first .vt-highlight-button {
  width: 100%;
}

@media (max-width: 900px) {
  .listing-layout__body {
    grid-template-columns: 1fr;
  }

  .listing-layout__sidebar {
    position: static;
    margin-top: 2rem;
    width: 100%;
  }
}

/* ==========================================================
   NOTICIAS
========================================================== */

.listing-layout--noticia .listing-layout__body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  grid-template-areas:
    "main filters";
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}

.listing-layout--noticia .listing-layout__main {
  grid-area: main;
  min-width: 0;
}

.listing-layout--noticia .listing-layout__featured {
  margin-bottom: clamp(2.5rem, 5vw, 4rem);
}

.listing-layout--noticia .listing-layout__featured .view-content {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.listing-layout--noticia .listing-layout__list .view {
  display: block !important;
}

.listing-layout--noticia .listing-layout__list .view-content {
  display: grid;
  gap: 1rem;
  min-width: 0;
}

/* Sacamos visualmente SOLO el filtro a la columna derecha */
.listing-layout--noticia .listing-layout__list .view-filters {
  position: absolute;
  top: 0;
  right: clamp(1rem, 4vw, 2.5rem);
  width: 320px;
}

.listing-layout--noticia .vt-container {
  position: relative;
}

/* ==========================================================
   EVENTOS
   Desktop:
   listado + filtro lateral
========================================================== */

.listing-layout--evento .listing-layout__list .view {
  /*display: grid; */
  grid-template-columns: minmax(0, 1fr) 320px;
  grid-template-areas:
    "content filters"
    "pager   filters";
  gap: clamp(2rem, 4vw, 4rem);
  align-items: start;
}

.listing-layout--evento .listing-layout__list .view-content {
  grid-area: content;
  display: grid;
  gap: 1.25rem;
}

.listing-layout--evento .listing-layout__list .view-filters {
  grid-area: filters;
  position: sticky;
  top: 7rem;
}

.listing-layout--evento .listing-layout__list .pager,
.listing-layout--evento .listing-layout__list nav.pager {
  grid-area: pager;
}

/* ==========================================================
   FILTRO COMÚN
========================================================== */

.listing-layout .view-filters {
  background: #f2f2f2;
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  box-shadow: var(--shadow-sm);
}

.listing-layout--noticia .view-filters::before {
  content: "Filtrar noticias";
}

.listing-layout--evento .view-filters::before {
  content: "Filtrar eventos";
}

.listing-layout .view-filters::before {
  display: block;
  margin-bottom: 1.25rem;
  color: var(--color-primary-dark);
  font-size: 1.25rem;
  line-height: 1.15;
  font-weight: 650;
  letter-spacing: -.02em;
}

/* FORMULARIO */

.listing-layout .views-exposed-form,
.listing-layout .form--inline,
.listing-layout .fieldset-wrapper {
  display: grid;
  gap: 1rem;
}

.listing-layout .form--inline {
  float: none;
}

.listing-layout fieldset {
  min-width: 0;
  margin: 0;
  padding: 0;
  border: 0;
}

.listing-layout legend {
  margin: 0 0 .75rem;
  padding: 0;
}

.listing-layout .fieldset-legend {
  color: var(--color-primary-dark);
  font-size: 1.1rem;
  line-height: 1.2;
  font-weight: 680;
}

.listing-layout .bef-toggle {
  display: none;
}

/* CHIPS */

.listing-layout .form-checkboxes,
.listing-layout .bef-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
}

.listing-layout .form-type-checkbox {
  position: relative;
  margin: 0;
}

.listing-layout .form-type-checkbox input[type="checkbox"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.listing-layout .form-type-checkbox label.option {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: .65rem .9rem;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  color: var(--color-primary-dark);
  font-size: .88rem;
  line-height: 1.15;
  font-weight: 520;
  cursor: pointer;
  user-select: none;
}

.listing-layout .form-type-checkbox input[type="checkbox"]:checked + label.option {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #fff;
}

/* BOTONES */

.listing-layout .form-actions {
  margin: .25rem 0 0;
}

.listing-layout .form-submit {
  width: 100%;
  min-height: 52px;
  border: 0;
  border-radius: var(--radius-sm);
  background: var(--color-primary);
  color: #fff;
  font-size: .95rem;
  font-weight: 620;
  cursor: pointer;
}

/* ==========================================================
   MÓVIL
========================================================== */

.filter-mobile-toggle {
  display: none;
}

@media (max-width: 700px) {

  .listing-layout--noticia .listing-layout__body {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "featured"
      "filters"
      "list";
  }

  .listing-layout--noticia .listing-layout__main,
  .listing-layout--noticia .listing-layout__list,
  .listing-layout--noticia .listing-layout__list .view {
    display: contents;
  }

  .listing-layout--noticia .listing-layout__featured {
    grid-area: featured;
  }

  .listing-layout--noticia .listing-layout__list .view-filters {
    grid-area: filters;
    position: static;
  }

  .listing-layout--noticia .listing-layout__list > .listing-layout__section-header,
  .listing-layout--noticia .listing-layout__list .view-content,
  .listing-layout--noticia .listing-layout__list .pager,
  .listing-layout--noticia .listing-layout__list nav.pager {
    grid-area: list;
  }

  .listing-layout--noticia .listing-layout__list > .listing-layout__section-header {
    margin-top: 1.5rem;
    margin-bottom: 0.1rem;
  }

  .listing-layout--noticia .listing-layout__featured .view-content {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .listing-layout--evento .listing-layout__list .view {
    grid-template-columns: 1fr;
    grid-template-areas:
      "filters"
      "content"
      "pager";
  }

  .listing-layout--evento .listing-layout__list .view-filters {
    position: static;
  }

  .listing-layout .view-filters {
    padding: 0;
    background: transparent;
    box-shadow: none;
  }

  .listing-layout .view-filters::before {
    display: none;
  }

  .filter-mobile-toggle {
    width: 100%;
    min-height: 54px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .85rem;
    margin-bottom: .75rem;
    padding: .9rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: #fff;
    color: var(--color-primary-dark);
    font-size: .98rem;
    font-weight: 700;
    cursor: pointer;
    box-shadow: var(--shadow-sm);
  }

  .filter-mobile-toggle::before {
    content: "\f0b0";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    color: var(--color-primary);
  }

  .filter-mobile-toggle::after {
    content: "\f078";
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    font-size: .8rem;
    color: var(--color-muted);
    transition: transform .18s ease;
  }

  .filter-mobile-toggle.is-open::after {
    transform: rotate(180deg);
  }

  .listing-layout .view-filters .views-exposed-form {
    display: none;
    padding: 1.25rem;
    background: #f2f2f2;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-sm);
  }

  .listing-layout .view-filters.is-open .views-exposed-form {
    display: grid;
  }
}

@media (max-width: 700px) {
  .listing-layout--noticia .listing-layout__list .view {
    display: grid !important;
    grid-template-columns: 1fr !important;
    grid-template-areas:
      "filters"
      "content"
      "pager";
    gap: 1rem;
  }

  .listing-layout--noticia .listing-layout__list .view-filters {
    grid-area: filters;
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 1rem !important;
  }

  .listing-layout--noticia .listing-layout__list .view-content {
    grid-area: content;
    width: 100% !important;
    max-width: 100% !important;
  }

  .listing-layout--noticia .filter-mobile-toggle {
    width: 100% !important;
    max-width: 100% !important;
  }

  .listing-layout--noticia .view-filters.is-open {
    margin-bottom: 1.25rem !important;
  }
}

@media (max-width: 700px) {

  .listing-layout--noticia .listing-layout__body {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }

  /* 1. Filtro */
  .listing-layout--noticia .listing-layout__list .view-filters {
    order: -30;

    position: static !important;

    width: 100% !important;
    max-width: 100% !important;

    margin: 0 !important;
  }

  /* 2. Destacadas */
  .listing-layout--noticia .listing-layout__featured {
    order: -20;
  }

  /* 3. Título últimas noticias */
  .listing-layout--noticia .listing-layout__list > .listing-layout__section-header {
    order: -10;
  }

  /* 4. Listado */
  .listing-layout--noticia .listing-layout__list .view-content {
    order: 10;
  }

  .listing-layout--noticia .listing-layout__list .pager,
  .listing-layout--noticia .listing-layout__list nav.pager {
    order: 20;
  }

  /* Layouts internos */
  .listing-layout--noticia .listing-layout__main,
  .listing-layout--noticia .listing-layout__list,
  .listing-layout--noticia .listing-layout__list .view {
    display: flex !important;
    flex-direction: column;
    gap: 1rem;
  }

  /* Destacadas una columna */
  .listing-layout--noticia .listing-layout__featured .view-content {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .listing-layout--noticia .filter-mobile-toggle {
    width: 100%;
  }
}
/*  LISTING NOTICIAS — MOBILE + LANDSCAPE */

@media (max-width: 900px) {

  .listing-layout--noticia .listing-layout__body {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: 1fr !important;
    gap: 1.5rem;
  }

  .listing-layout--noticia .listing-layout__main,
  .listing-layout--noticia .listing-layout__list,
  .listing-layout--noticia .listing-layout__list .view {
    display: flex !important;
    flex-direction: column !important;
    gap: 1rem;
    width: 100%;
  }

  .listing-layout--noticia .listing-layout__list .view-filters {
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    right: auto !important;
    top: auto !important;
    margin: 0 !important;
    order: -30;
  }

  .listing-layout--noticia .listing-layout__featured {
    order: -20;
  }

  .listing-layout--noticia .listing-layout__list > .listing-layout__section-header {
    order: -10;
  }

  .listing-layout--noticia .listing-layout__list .view-content {
    order: 10;
    width: 100% !important;
    max-width: 100% !important;
  }

  .listing-layout--noticia .listing-layout__list .pager,
  .listing-layout--noticia .listing-layout__list nav.pager {
    order: 20;
  }

  .listing-layout--noticia .listing-layout__featured .view-content {
    grid-template-columns: 1fr !important;
  }

  .listing-layout--noticia .listing-layout__sidebar {
    width: 100%;
    margin-top: 1rem;
  }
}

/* ==========================================================
   EVENTO: LISTADO COMPACTO (VIEW MODE) /actualidad/eventos
========================================================== */

.event-list-card {
  width: 100%;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition:
    transform .2s ease,
    box-shadow .2s ease,
    border-color .2s ease;
}

.event-list-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: rgba(17, 53, 85, .16);
}

.event-list-card__link {
  display: grid;
  grid-template-columns: 86px minmax(180px, 240px) minmax(0, 1fr) 48px;
  grid-template-areas: "date media content arrow";
  gap: 1.25rem;
  align-items: center;
  min-height: 156px;
  padding: 1rem;
  color: inherit;
  text-decoration: none;
}

.event-list-card__link:hover {
  text-decoration: none;
}

.event-list-card__link:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 3px #ffbf47;
}

.event-list-card__date {
  grid-area: date;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: .3rem;
  min-height: 112px;
  padding-right: 1rem;
  border-right: 1px solid var(--color-border);
  text-align: center;
  color: var(--color-primary-dark);
}

.event-list-card__date strong {
  font-size: clamp(1.7rem, 3vw, 2.35rem);
  line-height: .95;
  font-weight: 760;
  letter-spacing: -.06em;
  text-transform: uppercase;
}

.event-list-card__date span {
  color: var(--color-primary);
  font-size: .8rem;
  line-height: 1;
  font-weight: 760;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* Eventos multidía */
.event-list-card__date--multiday strong {
  font-size: clamp(1rem, 2vw, 1.35rem);
  letter-spacing: -.03em;
  white-space: nowrap;
}

.event-list-card__date--multiday span {
  font-size: .8rem;
  letter-spacing: .04em;
  white-space: nowrap;
}

.event-list-card__media {
  grid-area: media;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-md);
  aspect-ratio: 16 / 9;
  background: var(--color-primary-soft);
}

.event-list-card__media article,
.event-list-card__media .media,
.event-list-card__media .field,
.event-list-card__media .field__items,
.event-list-card__media .field__item,
.event-list-card__media picture,
.event-list-card__media img {
  width: 100%;
  height: 100%;
  display: block;
  margin: 0;
  padding: 0;
}

.event-list-card__media .field__label {
  display: none;
}

.event-list-card__media img {
  object-fit: cover;
  transition: transform .35s ease;
}

.event-list-card:hover .event-list-card__media img {
  transform: scale(1.035);
}

.event-list-card__content {
  grid-area: content;
  min-width: 0;
}

.event-list-card__category {
  margin-bottom: .55rem;
  color: var(--color-primary);
  font-size: .72rem;
  line-height: 1.2;
  font-weight: 760;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.event-list-card__title {
  margin: 0;
  color: var(--color-primary-dark);
  font-size: clamp(1.25rem, 2vw, 1.6rem);
  line-height: 1.15;
  font-weight: 700;
  letter-spacing: -.04em;
}

.event-list-card:hover .event-list-card__title {
  text-decoration: underline;
  text-underline-offset: 5px;
}

.event-list-card__place {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-top: .7rem;
  color: var(--color-muted);
  font-size: .92rem;
  line-height: 1.4;
  font-weight: 560;
}

.event-list-card__place i {
  flex-shrink: 0;
  color: var(--color-primary);
}

.event-list-card__summary {
  margin: .8rem 0 0;
  color: var(--color-muted);
  font-size: .94rem;
  line-height: 1.55;
}

.event-list-card__arrow {
  grid-area: arrow;
  justify-self: center;
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: var(--color-primary-soft);
  color: var(--color-primary);
  transition:
    background .2s ease,
    color .2s ease,
    transform .2s ease;
}

.event-list-card:hover .event-list-card__arrow {
  background: var(--color-primary);
  color: #fff;
  transform: translateX(3px);
}

@media (max-width: 760px) {
  .event-list-card__link {
    grid-template-columns: 74px minmax(0, 1fr) 42px;
    grid-template-areas:
      "media media media"
      "date content arrow";
    gap: 1rem;
    min-height: auto;
  }

  .event-list-card__media {
    aspect-ratio: 16 / 9;
  }

  .event-list-card__date {
    min-height: 92px;
    padding-right: .8rem;
  }

  .event-list-card__summary {
    display: none;
  }
}



/* ==========================================================
   BANDO ACTUALIDAD — PRO LIST /actualidad/bandos
========================================================== */

.bando-actualidad .view-content {
  display: grid;
  gap: .85rem;
}

.bando-card {
  background: #fff;
  border: 1px solid rgba(17, 53, 85, .12);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(17, 53, 85, .045);
  overflow: hidden;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}

.bando-card:hover {
  transform: translateY(-2px);
  border-color: rgba(17, 53, 85, .22);
  box-shadow: 0 18px 44px rgba(17, 53, 85, .09);
}

.bando-card__link {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto 42px;
  grid-template-areas: "icon content date arrow";
  gap: 1.35rem;
  align-items: center;
  min-height: 118px;
  padding: 1rem 1.15rem;
  color: inherit;
  text-decoration: none;
}

.bando-card__link:hover {
  text-decoration: none;
}

.bando-card__icon {
  grid-area: icon;
  width: 68px;
  height: 68px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: linear-gradient(180deg, #f1f6fb, #eaf2f8);
  color: var(--color-primary);
  font-size: 1.55rem;
}

.bando-card__content {
  grid-area: content;
  min-width: 0;
}

.bando-card__title {
  margin: 0;
  max-width: 760px;
  color: var(--color-primary-dark);
  font-size: clamp(1.08rem, 1.25vw, 1.28rem);
  line-height: 1.28;
  font-weight: 760;
  letter-spacing: -.035em;
}

.bando-card:hover .bando-card__title {
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 5px;
}

.bando-card__date {
  grid-area: date;
  justify-self: end;
  align-self: start;
  padding-top: .25rem;
  color: var(--color-muted);
  font-size: .82rem;
  line-height: 1.25;
  font-weight: 560;
  white-space: nowrap;
}

.bando-card__arrow {
  grid-area: arrow;
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  justify-self: end;
  border-radius: 999px;
  color: var(--color-primary-dark);
  font-size: 1rem;
  transition: transform .18s ease, background .18s ease, color .18s ease;
}

.bando-card:hover .bando-card__arrow {
  background: var(--color-primary-soft);
  color: var(--color-primary);
  transform: translateX(3px);
}

.bando-card__link:focus-visible {
  outline: none;
  box-shadow: inset 0 0 0 3px #ffbf47;
}

/* Responsive */

@media (max-width: 760px) {
  .bando-card__link {
    grid-template-columns: 58px minmax(0, 1fr) 32px;
    grid-template-areas:
      "icon content arrow"
      "icon date arrow";
    gap: .15rem .9rem;
    min-height: 96px;
    padding: 1rem;
  }

  .bando-card__icon {
    width: 52px;
    height: 52px;
    border-radius: 13px;
    font-size: 1.18rem;
  }

  .bando-card__title {
    font-size: 1rem;
    line-height: 1.3;
  }

  .bando-card__date {
    justify-self: start;
    align-self: start;
    padding-top: .35rem;
    font-size: .8rem;
  }

  .bando-card__arrow {
    width: 32px;
    height: 32px;
  }
} 


/* ==========================================================
   ACTUALIDAD PORTAL 2026
========================================================== */

.actualidad-portal {
  position: relative;

}


.actualidad-portal .vt-container {
  display: grid;
  gap: clamp(3rem, 6vw, 5rem);
}

.actualidad-portal__intro {
  max-width: 880px;
}

.actualidad-portal__eyebrow,
.actualidad-portal .vt-section-heading__eyebrow {
  margin: 0 0 .7rem;
  color: var(--color-primary);
  font-size: .78rem;
  line-height: 1.2;
  font-weight: 760;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.actualidad-portal__main-title {
  max-width: 820px;
  margin: 0;
  color: var(--color-primary-dark);
  font-size: clamp(2.45rem, 5vw, 4.75rem);
  line-height: .98;
  font-weight: 680;
  letter-spacing: -.065em;
}

.actualidad-portal__description {
  max-width: 680px;
  margin: 1.1rem 0 0;
  color: var(--color-muted);
  font-size: clamp(1.02rem, 1.4vw, 1.22rem);
  line-height: 1.7;
}

.actualidad-section {
  min-width: 0;
}

.actualidad-section--news {
  padding-bottom: clamp(1rem, 2vw, 1.5rem);
}

.actualidad-portal__secondary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .9fr);
  gap: clamp(2rem, 4vw, 3rem);
  align-items: start;
}

.actualidad-portal .vt-section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: 1.5rem;
}

.actualidad-portal .vt-section-heading__title {
  margin: 0;
  color: var(--color-primary-dark);
  font-size: clamp(1.85rem, 3vw, 2.65rem);
  line-height: 1.05;
  font-weight: 680;
  letter-spacing: -.045em;
}

.actualidad-portal .vt-section-heading__link {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  color: var(--color-primary);
  font-size: .94rem;
  line-height: 1.2;
  font-weight: 650;
  text-decoration: none;
  white-space: nowrap;
}

.actualidad-portal .vt-section-heading__link:hover {
  text-decoration-thickness: var(--link-underline-thickness);
  text-underline-offset: var(--link-underline-offset);
}

.actualidad-portal .vt-section-heading__link i {
  transition: transform .2s ease;
}

.actualidad-portal .vt-section-heading__link:hover i {
  transform: translateX(3px);
}

.actualidad-events-list,
.actualidad-bandos-list {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: clamp(1.15rem, 2vw, 1.5rem);
}

/* Drupal Views wrappers */

.actualidad-portal .view-content {
  display: grid;
  gap: 1rem;
}

.actualidad-portal .views-row {
  min-width: 0;
}

/* ==========================================================
   ACTUALIDAD: NOTICIAS GRID
========================================================== */

.actualidad-portal__list--news .view-content {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.25rem, 2vw, 1.75rem);
}

.actualidad-portal__list--news .views-row {
  min-width: 0;
  height: 100%;
  display: flex;
}

.actualidad-news-row {
  width: 100%;
  min-width: 0;
  height: 100%;
  background: transparent;
}

.actualidad-news-row__link {
  width: 100%;
  height: 100%;
  min-height: 100%;
  display: grid;
  grid-template-rows: 220px auto;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  color: inherit;
  text-decoration: none;
  transition:
    transform .18s ease,
    border-color .18s ease,
    box-shadow .18s ease;
}

.actualidad-news-row__link:hover {
  transform: translateY(-2px);
  border-color: rgba(17,53,85,.18);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
}

.actualidad-news-row__media {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 220px;
  overflow: hidden;
  background: var(--color-primary-soft);
}

.actualidad-news-row__media,
.actualidad-news-row__media .contextual-region,
.actualidad-news-row__media .field,
.actualidad-news-row__media .field__item,
.actualidad-news-row__media article,
.actualidad-news-row__media .media,
.actualidad-news-row__media picture,
.actualidad-news-row__media img {
  width: 100%;
  height: 100%;
  display: block;
}

.actualidad-news-row__media img {
  object-fit: cover;
  object-position: center;
  transition: transform .35s ease;
}

.actualidad-news-row__link:hover .actualidad-news-row__media img {
  transform: scale(1.03);
}

.actualidad-news-row__chip {
  position: absolute;
  top: 1rem;
  left: 1rem;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  max-width: calc(100% - 2rem);
  padding: .42rem .72rem;
  border-radius: 999px;
  background: rgba(255,255,255,.94);
  color: var(--color-primary-dark);
  box-shadow: 0 8px 20px rgba(17,53,85,.14);
  font-size: .7rem;
  line-height: 1;
  font-weight: 760;
  letter-spacing: .075em;
  text-transform: uppercase;
  white-space: nowrap;
}

.actualidad-news-row__content {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  padding: 1.2rem;
}

.actualidad-news-row__date {
  display: block;
  margin-bottom: .85rem;
  color: var(--color-primary);
  font-size: .74rem;
  line-height: 1;
  font-weight: 760;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.actualidad-news-row__title {
  margin: 0 0 .85rem;
  color: var(--color-primary-dark);
  font-size: clamp(1.05rem, 1.2vw, 1.25rem);
  line-height: 1.34;
  font-weight: 650;
  letter-spacing: -.015em;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.actualidad-news-row__link,
.actualidad-news-row__link:hover,
.actualidad-news-row__link:focus,
.actualidad-news-row__link:active {
  color: inherit;
  text-decoration: none;
}

.actualidad-news-row__link:hover .actualidad-news-row__title {
  text-decoration: underline;
  text-decoration-thickness: var(--link-underline-thickness);
  text-underline-offset: var(--link-underline-offset);
  text-decoration-skip-ink: auto;
}

.actualidad-news-row__date,
.actualidad-news-row__chip,
.actualidad-news-row__summary,
.actualidad-news-row__summary * {
  text-decoration: none !important;
}

.actualidad-news-row__summary {
  margin: 0;
  color: var(--color-muted);
  font-size: .94rem;
  line-height: 1.65;
  font-weight: 420;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.actualidad-news-row__summary .field,
.actualidad-news-row__summary .field__item,
.actualidad-news-row__summary p {
  margin: 0;
}

.actualidad-news-row__arrow {
  display: none;
}

@media (max-width: 1100px) {
  .actualidad-portal__list--news .view-content {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .actualidad-news-row__link {
    grid-template-rows: 210px auto;
  }

  .actualidad-news-row__media {
    min-height: 210px;
  }
}

@media (max-width: 700px) {
  .actualidad-portal__list--news .view-content {
    grid-template-columns: 1fr;
  }

  .actualidad-news-row__link {
    grid-template-rows: auto auto;
  }

  .actualidad-news-row__media {
    min-height: 0;
    aspect-ratio: 16 / 9;
  }

  .actualidad-news-row__content {
    padding: 1rem;
  }
}


/* ==========================================================
   ACTUALIDAD: EVENTOS NÓRDICO
========================================================== */

.actualidad-event-item {
  border-top: 1px solid var(--color-border);
}

.actualidad-event-item:first-child {
  border-top: 0;
}

.actualidad-event-item__link {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr) 30px;
  gap: 1rem;
  align-items: center;
  padding: 1.05rem 0;
  color: inherit;
  text-decoration: none;
}

.actualidad-event-item__link:hover {
  text-decoration: none;
}

.actualidad-event-item__date {
  min-height: 64px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: .18rem;
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  border-radius: var(--radius-sm);
  text-align: center;
}

.actualidad-event-item__date strong {
  font-size: 1.25rem;
  line-height: .95;
  font-weight: 760;
  letter-spacing: -.035em;
  text-transform: uppercase;
}

.actualidad-event-item__date span {
  color: var(--color-primary);
  font-size: .7rem;
  line-height: 1;
  font-weight: 760;
  letter-spacing: .06em;
  text-transform: uppercase;
}

/* Eventos multidía */
.actualidad-event-item__date--multiday strong {
  font-size: 1rem;
  letter-spacing: -.025em;
  white-space: nowrap;
}

.actualidad-event-item__category {
  margin-bottom: .25rem;
  color: var(--color-primary);
  font-size: .68rem;
  font-weight: 760;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.actualidad-event-item__title {
  margin: 0;
  color: var(--color-primary-dark);
  font-size: 1.02rem;
  line-height: 1.32;
  font-weight: 650;
  letter-spacing: -.018em;
}

.actualidad-event-item__arrow {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  color: var(--color-primary);
  transition: transform .2s ease;
}

.actualidad-event-item__link:hover .actualidad-event-item__title {
  text-decoration: underline;
  text-decoration-thickness: var(--link-underline-thickness);
  text-underline-offset: var(--link-underline-offset);
}


.actualidad-event-item__link:hover .actualidad-event-item__arrow {
  transform: translateX(3px);
}

/* ==========================================================
   ACTUALIDAD: BANDOS
========================================================== */

.actualidad-bando-row {
  border-top: 1px solid var(--color-border);
}

.actualidad-bando-row:first-child {
  border-top: 0;
}

.actualidad-bando-row__link {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: .9rem;
  align-items: center;
  min-height: 76px;
  padding: .9rem 0;
  color: inherit;
  text-decoration: none;
}

.actualidad-bando-row__link:hover {
  text-decoration: none;
}

.actualidad-bando-row__icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: var(--radius-sm);
  background: var(--color-primary-soft);
  color: var(--color-primary);
}

.actualidad-bando-row__title {
  margin: 0;
  color: var(--color-primary-dark);
  font-size: .98rem;
  line-height: 1.35;
  font-weight: 650;
  letter-spacing: -.01em;
}

.actualidad-bando-row__priority {
  margin-top: .25rem;
  color: var(--color-muted);
  font-size: .74rem;
  line-height: 1.2;
  font-weight: 650;
}

.actualidad-bando-row__priority .field,
.actualidad-bando-row__priority .field__item {
  display: inline;
}

.actualidad-bando-row__priority .field__label {
  display: none;
}

.actualidad-bando-row__date {
  color: var(--color-muted);
  font-size: .78rem;
  font-weight: 650;
  white-space: nowrap;
}

.actualidad-bando-row__link:hover .actualidad-bando-row__title {
  text-decoration: underline;
  text-decoration-thickness: var(--link-underline-thickness);
  text-underline-offset: var(--link-underline-offset);
}

/* ==========================================================
   ACTUALIDAD RESPONSIVE
========================================================== */

@media (max-width: 1100px) {
  .actualidad-portal__secondary {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .actualidad-portal {
    padding-block: 2.5rem;
  }

  .actualidad-portal .vt-container {
    gap: 3rem;
  }

  .actualidad-portal .vt-section-heading {
    align-items: flex-start;
    flex-direction: column;
  }

  .actualidad-news-row__link {
    grid-template-columns: 1fr;
    gap: 0;
    min-height: auto;
    padding: 0;
  }

  .actualidad-news-row__media {
    width: 100%;
    min-height: 0;
    aspect-ratio: 16 / 9;
  }

  .actualidad-news-row__content {
    padding: 1rem;
  }

  .actualidad-news-row__arrow {
    display: none;
  }

  .actualidad-event-item__link {
    grid-template-columns: 68px minmax(0, 1fr);
  }

  .actualidad-event-item__arrow {
    display: none;
  }

  .actualidad-bando-row__link {
    grid-template-columns: 42px minmax(0, 1fr);
  }

  .actualidad-bando-row__date {
    grid-column: 2;
  }
}