/* Home responsive add-on layer (mobile-first + performance friendly) */

/* Base safeguards: overflow, viewport fit and reveal helper */
html,
.liga-body {
  max-width: 100%;
  overflow-x: hidden;
}

.liga-container,
.liga-home,
.liga-home .liga-grid > *,
.liga-hero-layout > *,
.liga-card,
.liga-section-head,
.liga-header-inner,
.liga-footer-grid > *,
.liga-single-post__layout > *,
.liga-match-single__layout > *,
.liga-news-archive__layout > *,
.liga-standings-page__layout > * {
  min-width: 0;
}

.liga-body svg,
.liga-body video,
.liga-body canvas {
  max-width: 100%;
}

.liga-table-wrap {
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

.liga-table-wrap::-webkit-scrollbar {
  height: 0.45rem;
}

.liga-table-wrap::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: rgba(11, 42, 102, 0.32);
}

.liga-body.liga-menu-open {
  overflow: hidden;
}

.is-reveal-pending {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity 360ms ease, transform 420ms ease;
}

.is-reveal-pending.is-visible,
.is-reveal-pending.is-revealed {
  opacity: 1;
  transform: translateY(0);
}

/* Fallback defensivo: la tabla del home nunca debe quedar oculta por reveal */
.liga-home .liga-home-main-panels,
.liga-home .liga-home-main-panels-grid,
.liga-home .liga-standings-panel,
.liga-home .liga-standings-panel.is-reveal-pending,
.liga-home .liga-standings-panel.is-visible,
.liga-home .liga-standings-panel.is-revealed {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

/* Fallback defensivo: si JS deja hidden por error en el panel activo */
.liga-home .liga-table-wrap.is-visible,
.liga-home .liga-table-wrap.is-revealed,
.liga-home .liga-table-wrap[hidden].is-visible,
.liga-home .liga-table-wrap[hidden].is-revealed {
  display: block !important;
}

.liga-home .liga-standings-panel .liga-table-wrap:first-of-type[hidden] {
  display: block !important;
}

/* Sticky state hook handled by JS */
.liga-header.liga-header--scrolled {
  box-shadow: 0 16px 34px rgba(2, 8, 20, 0.45);
}

/* Header/nav touch ergonomics */
.liga-header-nav-link,
.liga-header-menu-button,
.liga-header-search-button,
.liga-header-admin-cta {
  touch-action: manipulation;
}

/* ------------------------------- */
/* @media (max-width: 1200px)      */
/* ------------------------------- */
@media (max-width: 1200px) {
  .liga-container {
    width: min(var(--liga-container-max), calc(100% - 2rem));
  }

  .liga-home > section:not(.liga-hero) {
    padding-block: 2.6rem;
  }

  .liga-header-inner {
    min-height: 76px;
    gap: 0.75rem;
    grid-template-columns: auto 1fr auto;
  }

  .liga-header-nav {
    justify-self: end;
  }

  .liga-header-nav-list {
    gap: 0.1rem;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .liga-header-nav-link {
    padding: 0.4rem 0.62rem;
    font-size: 0.88rem;
  }

  .liga-hero-slide {
    grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr);
    gap: 1.1rem;
  }

  .liga-hero-title {
    font-size: clamp(2rem, 6.2vw, 4.4rem);
  }

  .liga-hero-media {
    min-height: 360px;
  }

  .liga-home-main-panels-grid {
    grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr) minmax(0, 1fr);
  }

  .liga-public-standings-page .liga-container.liga-standings-page__container {
    width: min(1520px, calc(100% - 1.5rem));
  }

  .liga-standings-page__layout {
    grid-template-columns: minmax(0, 1fr) 320px;
  }

  .liga-single-post__layout {
    grid-template-columns: minmax(0, 1.5fr) minmax(260px, 1fr);
    gap: 1.05rem;
  }

  .liga-match-single__layout {
    grid-template-columns: minmax(0, 1.52fr) minmax(260px, 1fr);
    gap: 1.02rem;
  }

  .liga-news-archive__layout {
    grid-template-columns: minmax(0, 1.58fr) minmax(280px, 0.82fr);
    gap: 0.92rem;
  }

  .liga-news-featured__media {
    min-height: 300px;
  }

  .liga-news-featured__title {
    font-size: clamp(1.38rem, 2.3vw, 1.86rem);
  }

  .liga-news-card-content {
    padding: 0.85rem;
  }
}

/* ------------------------------ */
/* @media (max-width: 992px)      */
/* ------------------------------ */
@media (max-width: 992px) {
  .liga-home > section:not(.liga-hero) {
    padding-block: 2.3rem;
  }

  .liga-header-inner {
    min-height: 72px;
    grid-template-columns: auto auto 1fr auto;
    gap: 0.5rem;
  }

  .liga-header-menu-button {
    display: inline-flex;
  }

  .liga-header-nav {
    position: absolute;
    grid-column: 1 / -1;
    top: calc(100% + 0.45rem);
    left: 0;
    right: 0;
    z-index: 80;
    display: none;
    width: 100%;
    max-height: calc(100vh - 7rem);
    overflow: auto;
    padding: 0.65rem;
    border-radius: var(--liga-radius-md);
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(5, 10, 24, 0.98);
    box-shadow: var(--liga-shadow-md);
    justify-self: stretch;
  }

  .liga-header-nav.liga-nav-open {
    display: block;
  }

  .liga-header-nav-list {
    flex-direction: column;
    align-items: stretch;
    gap: 0.24rem;
  }

  .liga-header-nav-link {
    justify-content: flex-start;
    min-height: 44px;
    padding: 0.65rem 0.75rem;
    border-radius: var(--liga-radius-sm);
  }

  .liga-header-actions {
    gap: 0.42rem;
  }

  .liga-partidos-archive__filters {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .liga-partidos-archive__actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }

  .liga-header-search-form {
    flex-wrap: wrap;
  }

  .liga-header-search-form input[type="search"] {
    width: 100%;
    min-height: 44px;
  }

  .liga-header-search-submit {
    width: 100%;
  }

  .liga-header-admin-cta {
    min-height: 42px;
    padding-inline: 0.8rem;
    font-size: 0.78rem;
  }

  .liga-hero {
    padding-block: 1.35rem 2.15rem;
  }

  .liga-hero-slide {
    grid-template-columns: 1fr;
  }

  .liga-hero-content {
    max-width: 100%;
  }

  .liga-hero-media {
    min-height: 320px;
  }

  .liga-home-main-panels-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .liga-home-main-panels .liga-standings-panel,
  .liga-home-main-panels .liga-results-panel,
  .liga-home-main-panels .liga-fixture-panel {
    min-height: 0;
  }

  .liga-home-main-panels .liga-results-list,
  .liga-home-main-panels .liga-fixture-list {
    max-height: none;
    overflow-y: visible;
  }

  .liga-single-post__layout {
    grid-template-columns: minmax(0, 1.32fr) minmax(240px, 0.95fr);
    gap: 0.9rem;
  }

  .liga-single-post__content {
    padding: 0.95rem;
  }

  .liga-single-post__title {
    font-size: clamp(1.5rem, 3.8vw, 2.1rem);
  }

  .liga-standings-page__layout {
    grid-template-columns: minmax(0, 1fr) 280px;
  }

  .liga-news-archive__layout {
    grid-template-columns: 1fr;
    gap: 0.82rem;
  }

  .liga-news-featured__article {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  }

  .liga-news-featured__content {
    padding: 0.9rem;
  }

  .liga-news-featured__title {
    font-size: clamp(1.28rem, 3.1vw, 1.8rem);
  }

  .liga-news-sidebar {
    gap: 0.76rem;
  }

  .liga-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .liga-news-archive .liga-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .liga-sponsors-item {
    flex-basis: calc((100% - 1.44rem - (var(--liga-sponsors-edge-space, 3rem) * 2)) / 3);
  }

  .liga-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ------------------------------ */
/* @media (max-width: 768px)      */
/* ------------------------------ */
@media (max-width: 768px) {
  .liga-home > section:not(.liga-hero) {
    padding-block: 2rem;
  }

  .liga-topbar {
    display: none;
  }

  .liga-section-head {
    flex-wrap: wrap;
  }

  .liga-section-link {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
  }

  .liga-topbar-inner {
    row-gap: 0.35rem;
    min-height: auto;
    padding-block: 0.4rem;
  }

  .liga-topbar-social {
    margin-right: 0;
    width: 100%;
  }

  .liga-topbar-social-list {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.45rem 0.7rem;
  }

  .liga-topbar-social-link {
    min-height: 34px;
  }

  .liga-topbar__menu .sub-menu {
    position: static;
    display: none;
    min-width: 0;
    margin-top: 0.2rem;
    border-radius: 0.5rem;
  }

  .liga-topbar__item:focus-within > .sub-menu,
  .liga-topbar__item:hover > .sub-menu {
    display: block;
  }

  .liga-header-brand-name {
    max-width: 170px;
    font-size: 0.98rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .liga-hero {
    padding-top: 1.1rem;
  }

  .liga-hero-content.liga-hero-layout__content {
    padding: 1.25rem;
  }

  .liga-hero-title {
    font-size: clamp(1.9rem, 10vw, 3.2rem);
  }

  .liga-hero-description {
    font-size: 0.95rem;
  }

  .liga-hero-actions {
    width: 100%;
    gap: 0.52rem;
  }

  .liga-hero-actions > * {
    flex: 1 1 180px;
    min-height: 44px;
  }

  .liga-hero-media {
    min-height: 260px;
  }

  .liga-hero-slider__arrow {
    width: 2.35rem;
    height: 2.35rem;
    font-size: 1.35rem;
  }

  .liga-hero-slider__dots {
    margin-top: 0.72rem;
  }

  .liga-home-main-panels-grid {
    grid-template-columns: 1fr;
  }

  .liga-division-tabs {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.1rem;
    -webkit-overflow-scrolling: touch;
  }

  .liga-division-tab {
    flex: 0 0 auto;
  }

  .liga-standings-table {
    min-width: 620px;
  }

  .liga-standings-table th,
  .liga-standings-table td {
    white-space: nowrap;
  }

  .liga-standings-table td:nth-child(3),
  .liga-standings-page .liga-standings-table td:nth-child(2) {
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .liga-partidos-archive__scoreboard {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 0.52rem;
  }

  .liga-partidos-archive__score {
    min-width: 0;
    width: min(100%, 210px);
  }

  .liga-partidos-archive__team-logo {
    width: 50px;
    height: 50px;
  }

  .liga-partidos-archive__footer {
    justify-content: flex-start;
  }

  .liga-single-post {
    padding-block: 0.8rem 1.4rem;
  }

  .liga-single-post__layout {
    grid-template-columns: 1fr;
    gap: 0.8rem;
  }

  .liga-match-hero {
    padding-top: 0.92rem;
    padding-bottom: 1.1rem;
  }

  .liga-match-scoreboard {
    gap: 0.72rem;
  }

  .liga-match-hero__facts {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.48rem;
  }

  .liga-match-single__layout {
    grid-template-columns: 1fr;
    gap: 0.82rem;
  }

  .liga-match-single__sidebar {
    gap: 0.75rem;
  }

  .liga-news-archive__hero {
    padding-top: 1rem;
    padding-bottom: 1.2rem;
  }

  .liga-news-archive__title {
    font-size: clamp(1.7rem, 9.2vw, 2.35rem);
  }

  .liga-news-archive__subtitle {
    font-size: 0.92rem;
  }

  .liga-news-featured__article {
    grid-template-columns: 1fr;
  }

  .liga-news-featured__media {
    min-height: 250px;
  }

  .liga-news-featured__content::before {
    border-left: 0;
    border-top: 1px solid rgba(11, 42, 102, 0.08);
  }

  .liga-news-archive .liga-news-grid {
    grid-template-columns: 1fr;
  }

  .liga-news-card__content {
    padding: 0.8rem;
  }

  .liga-news-widget {
    padding: 0.72rem;
  }

  .liga-news-widget__link {
    grid-template-columns: 76px minmax(0, 1fr);
  }

  .liga-news-widget__thumb {
    width: 76px;
    height: 54px;
  }

  .liga-single-post__sidebar {
    gap: 0.75rem;
  }

  .liga-single-post__nav {
    grid-template-columns: 1fr;
  }

  .liga-single-post__nav-link--next {
    text-align: left;
  }

  .liga-single-post__result-scoreline {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  }

  .liga-standings-page-hero {
    padding-top: 0.5rem;
  }

  .liga-standings-page-title {
    font-size: clamp(1.4rem, 7.2vw, 2rem);
  }

  .liga-standings-page__layout {
    grid-template-columns: 1fr;
    gap: 0.78rem;
  }

  .liga-standings-page__sidebar {
    gap: 0.75rem;
  }

  .liga-standings-panel,
  .liga-standings-sidebar-widget,
  .liga-results-panel,
  .liga-fixture-panel {
    padding: 0.72rem;
  }

  .liga-standings-page .liga-standings-context-nav__list {
    gap: 0.34rem;
  }

  .liga-standings-page .liga-standings-context-nav__link {
    font-size: 0.74rem;
  }

  .liga-result-card,
  .liga-fixture-card {
    padding: 0.68rem;
  }

  .liga-result-head,
  .liga-fixture-head {
    align-items: flex-start;
  }

  .liga-result-division,
  .liga-result-date,
  .liga-fixture-division,
  .liga-fixture-date,
  .liga-fixture-venue {
    overflow-wrap: anywhere;
  }

  .liga-result-team-logo {
    width: 36px;
    height: 36px;
  }

  .liga-fixture-team-logo {
    width: 50px;
    height: 50px;
  }

  .liga-result-score {
    min-width: 84px;
    font-size: clamp(1.3rem, 6.5vw, 1.7rem);
  }

  .liga-result-body {
    grid-template-columns: minmax(34px, 1fr) auto minmax(34px, 1fr);
  }

  .liga-result-score {
    flex-shrink: 0;
  }

  .liga-fixture-team-name,
  .liga-partidos-archive__team-name,
  .liga-match-team__name {
    overflow-wrap: anywhere;
    hyphens: auto;
  }

  .liga-news-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .liga-news-card-title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .liga-sponsors-item {
    flex-basis: calc((100% - 0.72rem - (var(--liga-sponsors-edge-space, 3rem) * 2)) / 2);
    min-width: 0;
    min-height: 90px;
  }

  .liga-sponsors-logo {
    max-width: 100%;
    object-fit: contain;
  }

  .liga-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.1rem;
  }

  .liga-footer-legal-inner {
    min-height: auto;
    flex-wrap: wrap;
    padding-block: 0.7rem;
  }

  .liga-footer-legal-copy,
  .liga-footer-legal-extra,
  .liga-footer-contact-link {
    overflow-wrap: anywhere;
  }
}

/* ------------------------------ */
/* @media (max-width: 576px)      */
/* ------------------------------ */
@media (max-width: 576px) {
  .liga-container {
    width: min(100% - 1.25rem, var(--liga-container-max, 1200px));
  }

  .liga-card.liga-partidos-archive__item {
    padding: 0.92rem;
    gap: 0.56rem;
  }

  .liga-partidos-archive__item .liga-partidos-archive__match-title {
    margin-top: 0.2rem;
  }

  .liga-home > section:not(.liga-hero) {
    padding-block: 1.6rem;
  }

  .liga-single-post__content {
    padding: 0.82rem;
  }

  .liga-partidos-archive__title {
    font-size: clamp(1.45rem, 8.5vw, 2.05rem);
  }

  .liga-partidos-archive__filters {
    grid-template-columns: 1fr;
    gap: 0.52rem;
  }

  .liga-partidos-archive__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .liga-partidos-archive__actions .liga-btn {
    width: 100%;
  }

  .liga-partidos-archive__meta {
    flex-wrap: wrap;
  }

  .liga-partidos-archive__team-name {
    font-size: 0.78rem;
  }

  .liga-fixture-team-logo {
    width: 46px;
    height: 46px;
  }

  .liga-fixture-teams {
    column-gap: 0.48rem;
  }

  .liga-fixture-team-name {
    font-size: 0.78rem;
  }

  .liga-partidos-archive__facts li {
    font-size: 0.8rem;
  }

  .liga-match-title {
    font-size: clamp(1.35rem, 8.5vw, 1.95rem);
  }

  .liga-match-hero__meta {
    gap: 0.34rem;
  }

  .liga-match-scoreboard {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 0.64rem;
  }

  .liga-match-team__logo {
    width: 78px;
    height: 78px;
  }

  .liga-match-score {
    min-width: 0;
    width: min(100%, 230px);
  }

  .liga-match-hero__facts {
    grid-template-columns: 1fr;
  }

  .liga-match-details__row {
    grid-template-columns: 1fr;
    gap: 0.18rem;
  }

  .liga-match-details__row dt {
    font-size: 0.72rem;
  }

  .liga-match-details__row dd {
    font-size: 0.86rem;
  }

  .liga-news-archive__body {
    padding-top: 0.84rem;
  }

  .liga-news-featured__media {
    min-height: 220px;
  }

  .liga-news-featured__title {
    font-size: clamp(1.24rem, 7.2vw, 1.66rem);
  }

  .liga-news-card__title {
    font-size: clamp(1rem, 5.8vw, 1.18rem);
  }

  .liga-news-widget__tags a {
    min-height: 1.78rem;
    padding-inline: 0.56rem;
    font-size: 0.72rem;
  }

  .liga-pagination .page-numbers {
    gap: 0.3rem;
  }

  .liga-pagination .page-numbers a,
  .liga-pagination .page-numbers span {
    min-width: 2.08rem;
    min-height: 2.08rem;
    padding-inline: 0.58rem;
    font-size: 0.8rem;
  }

  .liga-single-post__title {
    font-size: clamp(1.4rem, 8vw, 1.9rem);
  }

  .liga-single-post__entry {
    font-size: 0.95rem;
    line-height: 1.64;
  }

  .liga-single-post__latest-link {
    grid-template-columns: 74px minmax(0, 1fr);
    gap: 0.54rem;
    padding: 0.42rem;
  }

  .liga-single-post__latest-thumb {
    width: 74px;
    height: 54px;
  }

  .liga-single-post__result-team {
    font-size: 0.76rem;
  }

  .liga-single-post__fixture-teams {
    font-size: 0.8rem;
  }

  .liga-topbar {
    font-size: 0.7rem;
  }

  .liga-topbar-social-list {
    gap: 0.4rem 0.6rem;
  }

  .liga-header-inner {
    min-height: 66px;
    grid-template-columns: auto auto 1fr;
  }

  .liga-header-brand-figure {
    width: auto;
    height: auto;
  }

  .liga-header-brand-logo {
    width: auto;
    height: auto;
    max-height: 50px;
    max-width: min(40vw, 150px);
  }

  .liga-header-brand-name {
    max-width: 120px;
    font-size: 0.88rem;
  }

  .liga-header-search-button {
    width: 2.2rem;
    height: 2.2rem;
  }

  .liga-header-search-submit {
    min-height: 40px;
    font-size: 0.76rem;
  }

  .liga-header-admin-cta {
    min-height: 40px;
    padding-inline: 0.62rem;
    font-size: 0.72rem;
  }

  .liga-hero-title {
    font-size: clamp(1.7rem, 11vw, 2.55rem);
  }

  .liga-hero-description {
    font-size: 0.9rem;
  }

  .liga-hero-actions > * {
    flex: 1 1 100%;
  }

  .liga-hero-media {
    min-height: 210px;
    max-height: 48vh;
  }

  .liga-standings-table {
    font-size: 0.78rem;
  }

  .liga-standings-table thead th,
  .liga-standings-table tbody th,
  .liga-standings-table tbody td {
    padding: 0.5rem 0.42rem;
  }

  /* Mantener datos deportivos completos; el scroll vive en .liga-table-wrap. */
  .liga-standings-table th:nth-child(6),
  .liga-standings-table td:nth-child(6),
  .liga-standings-table th:nth-child(7),
  .liga-standings-table td:nth-child(7) {
    display: table-cell;
  }

  .liga-standings-page .liga-standings-table {
    min-width: 760px;
  }

  .liga-standings-page .liga-standings-team {
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 0.36rem;
  }

  .liga-standings-page .liga-standings-table th:nth-child(6),
  .liga-standings-page .liga-standings-table td:nth-child(6),
  .liga-standings-page .liga-standings-table th:nth-child(7),
  .liga-standings-page .liga-standings-table td:nth-child(7) {
    display: table-cell;
  }

  .liga-table-team-logo {
    width: 30px;
    height: 30px;
  }

  .liga-result-body {
    grid-template-columns: minmax(34px, auto) auto minmax(34px, auto);
  }

  .liga-fixture-head {
    flex-wrap: wrap;
  }

  .liga-fixture-teams {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    column-gap: 0.58rem;
    row-gap: 0.36rem;
  }

  .liga-fixture-versus {
    grid-column: 2;
    grid-row: 1 / span 2;
    justify-self: center;
  }

  .liga-news-grid {
    grid-template-columns: 1fr;
  }

  .liga-news-card-media {
    aspect-ratio: 15 / 9;
  }

  .liga-sponsors-item {
    flex-basis: calc((100% - 0.72rem - (var(--liga-sponsors-edge-space, 2.4rem) * 2)) / 2);
  }

  .liga-footer-grid {
    grid-template-columns: 1fr;
  }

  .liga-footer-social-list {
    grid-template-columns: repeat(2, minmax(0, max-content));
  }

  .liga-footer-legal-list {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.38rem;
  }
}

@media (max-width: 420px) {
  .liga-sponsors-item {
    flex-basis: 80%;
  }
}

@media (prefers-reduced-motion: reduce) {
  .is-reveal-pending {
    opacity: 1;
    transform: none;
    transition: none;
  }
}
