/* ═══════════════════════════════════════════════════════
   responsive.css — Tablet & Desktop layouts
   Phone (< 640px) is untouched — handled by base + components
═══════════════════════════════════════════════════════ */

/* ── Tablet 640px – 1023px ──────────────────────────── */
@media (min-width: 640px) {
  .app-shell,
  .bottom-nav,
  .cona-global-header { max-width: 100%; width: 100%; }

  /* Auth / onboarding — constrain to readable width */
  #screen-auth-login,
  #screen-auth-register,
  #screen-setup-profile {
    max-width: 540px;
    margin: 0 auto;
  }
}

@media (min-width: 768px) {
  :root {
    --page-pad-x: 48px;
    --page-card-pad: 20px;
    --page-card-radius: 16px;
    --page-grid-gap: 14px;
    --page-icon-btn: 40px;
  }

  .cona-global-header {
    padding-left: var(--page-pad-x);
    padding-right: var(--page-pad-x);
  }

  /* Tablet lateral padding — applied to CONA's actual page wrappers. */
  .page-container,
  .main-content,
  [class*="page-wrapper"],
  .topbar,
  .home-heading,
  .date-section,
  .games-sec,
  .resultado-sec,
  .goles-sec,
  .page-hdr,
  .stats-grid,
  .historial-sec,
  .rating-podium-sec,
  .podium-sec,
  .sec-divider,
  .hub-header,
  .hub-section-label,
  .hub-list,
  .ins-topbar,
  .ins-cap-wrap,
  .reg-spot-cols,
  .published-teams-section,
  .form-wrap,
  .req-teams-grid,
  .auth-wrap,
  .setup-wrap,
  .conf-wrap,
  .pfl-center,
  .rf-field,
  .rf-sec,
  .rf-mvp-sec,
  .profile-action-bar,
  .profile-wrap,
  .settings-hdr,
  .settings-section,
  .admin-hdr,
  .admin-edit-hdr,
  .admin-edit-info,
  .admin-score-sec,
  .admin-mvp-sec,
  .admin-team-sec,
  .admin-list,
  .org-teams-hdr,
  .org-teams-body,
  .org-teams-footer,
  .org-mode-tabs,
  .org-sb,
  .org-grid-view,
  .org-action-view {
    box-sizing: border-box;
    max-width: none;
    width: 100%;
    padding-left: var(--page-pad-x);
    padding-right: var(--page-pad-x);
  }

  .stats-strip,
  .gt,
  .alist,
  .mvp-list,
  .rend-tbl,
  .kt,
  .jdm,
  .wa-banner,
  .crear-card,
  .plist-card,
  .banca-section {
    max-width: none;
    margin-left: var(--page-pad-x);
    margin-right: var(--page-pad-x);
  }

  .admin-save-btn {
    width: calc(100% - (var(--page-pad-x) * 2));
    margin-left: var(--page-pad-x);
    margin-right: var(--page-pad-x);
  }

  #screen-auth-login,
  #screen-auth-register,
  #screen-auth-phone,
  #screen-setup-profile {
    max-width: 100%;
  }

  .auth-wrap,
  .setup-wrap,
  .conf-wrap,
  .pfl-center {
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
  }

  #matchCards,
  #hubGamesList {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
    gap: var(--page-grid-gap);
  }

  .req-teams-grid,
  .stats-grid {
    gap: var(--page-grid-gap);
  }

  .game-card,
  .hist-item,
  .admin-card,
  .profile-hist-item,
  .settings-row,
  .inbox-msg,
  .fc-norm-item,
  .fc-scale-item,
  .reserve-card,
  .conf-card,
  .crear-card,
  .perf-card {
    border-radius: var(--page-card-radius);
    padding: var(--page-card-pad);
  }

  .resultado-card,
  .plist-card,
  .req-team-card,
  .cona-credits-card,
  .saved-card-item,
  .rf-mvp-card,
  .org-setup-col,
  .org-grid-section,
  .org-action-team,
  .org-action-pick {
    border-radius: var(--page-card-radius);
  }

  .join-pill,
  .sub-btn,
  .req-confirm-btn,
  .req-join-btn,
  .crear-cta-btn,
  .auth-btn,
  .auth-btn-outline,
  .back-home-btn,
  .admin-save-btn,
  .fc-entry-btn,
  .fc-feedback-btn,
  .onboarding-terms-btn,
  .credit-exit-primary,
  .credit-exit-secondary,
  .pfl-cta-btn {
    min-height: var(--page-action-h);
    padding-left: 18px;
    padding-right: 18px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 800;
  }

  .share-btn,
  .admin-btn,
  .settings-gear,
  .inbox-btn {
    width: var(--page-icon-btn);
    height: var(--page-icon-btn);
    border-radius: 12px;
  }
}

/* ── Desktop 1024px+ ────────────────────────────────── */
@media (min-width: 1024px) {
  :root {
    --page-pad-x: 120px;
    --page-card-pad: 24px;
    --page-card-radius: 16px;
    --page-grid-gap: 16px;
    --page-icon-btn: 40px;
  }

  body {
    justify-content: flex-start;
  }

  .app-shell {
    max-width: 100%;
    width: 100%;
  }

  /* Bottom nav spans full width */
  .bottom-nav {
    max-width: 100%;
    width: 100%;
    left: 0;
    transform: none;
  }

  .nav-item:hover { color: var(--text2); }

  /* ──────────────────────────────────────
     Screens — centered readable column
  ────────────────────────────────────── */
  .screen {
    padding-bottom: 100px; /* extra room above fixed nav */
  }

  /* ──────────────────────────────────────
     Cards — responsive within the 120px rail
  ────────────────────────────────────── */
  #matchCards {
    grid-template-columns: repeat(auto-fit, minmax(330px, 1fr));
  }

  /* ──────────────────────────────────────
     Auth / onboarding — narrow forms
  ────────────────────────────────────── */
  #screen-auth-login,
  #screen-auth-register,
  #screen-setup-profile {
    max-width: 100%;
  }

  .form-wrap,
  .landing-wrap { max-width: none; }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-delay: 0ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
  }

  .screen.active {
    animation: none !important;
  }
}
