/**
 * El Manantial — estilos solo para viewport ancho (tablet/escritorio).
 * Cargar con: media="(min-width: 768px)" para no aplicar nada en móvil.
 * Móvil: ver styles.css (base) + reglas max-width para mosaico animales/partos.
 */

/* Animales / Partos — mosaico más denso en monitores grandes */
@media (min-width: 1100px) {
  #pg-ani .ani-gallery-mosaic,
  #pg-nac .nac-gallery-mosaic {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  }
}
@media (min-width: 1400px) {
  #pg-ani .ani-gallery-mosaic,
  #pg-nac .nac-gallery-mosaic {
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
  }
}
@media (min-width: 1700px) {
  #pg-ani .ani-gallery-mosaic,
  #pg-nac .nac-gallery-mosaic {
    grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  }
}
@media (min-width: 2000px) {
  #pg-ani .ani-gallery-mosaic,
  #pg-nac .nac-gallery-mosaic {
    grid-template-columns: repeat(8, minmax(0, 1fr)) !important;
  }
}

/* Escritorio ancho — densidad opcional (solo ≥1100px) */
@media (min-width: 1100px) {
  body.manto-serio-v1-app {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }
  body.manto-serio-v1-app #app .pg {
    font-weight: 400;
  }
  body.manto-serio-v1-app .btn {
    height: 38px;
    min-height: 38px;
    padding: 0 12px;
    font-size: 13px;
    font-weight: 600;
  }
  body.manto-serio-v1-app .vb {
    padding: 5px 10px;
    font-size: 11px;
    font-weight: 600;
  }
  body.manto-serio-v1-app .vb.active {
    font-weight: 700;
  }
  body.manto-serio-v1-app .fp {
    height: 30px;
    padding: 0 11px;
    font-size: 11px;
    font-weight: 600;
  }
  body.manto-serio-v1-app .fp.active {
    font-weight: 700;
  }
  body.manto-serio-v1-app .tb {
    padding: 6px 11px;
    font-size: 11px;
    font-weight: 600;
  }
  body.manto-serio-v1-app .tb.active {
    font-weight: 700;
  }
  #pg-ani .ac {
    padding: 6px 10px;
    margin-bottom: 3px;
    gap: 8px;
    border-radius: 4px;
  }
  #pg-ani .aph {
    width: 44px;
    height: 44px;
    border-radius: 6px;
    border-width: 1px;
  }
  #pg-ani .anom {
    font-size: 13px;
    font-weight: 600;
  }
  #pg-ani .amet {
    font-size: 11px;
    font-weight: 500;
  }
  #pg-ani .ani-gallery-mosaic .gbdy {
    padding: 7px 9px;
  }
  #pg-ani .ani-gallery-mosaic .gnom {
    font-size: 12px;
    font-weight: 600;
  }
  #pg-ani .ani-gallery-mosaic .gmet {
    font-size: 10px;
    font-weight: 500;
  }
  #pg-ani .swrap .sinp {
    padding: 0 42px 0 31px;
    font-size: 13px;
    font-weight: 600;
  }
  #pg-ani .swrap .sico {
    left: 10px;
  }
  #pg-nac .nac-gallery-mosaic .nac-mosaic-card > div:last-child {
    padding: 6px 7px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   Dashboard Inicio — SOLO escritorio (≥768px).
   Ancho completo como Reproducción/Alertas: la grilla 2-col anterior
   apuntaba hijos directos que no existen (.section envuelve todo) y
   reservaba ~260px vacíos a la derecha → contenido “recortado”.
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 768px) {
  body.manto-serio-v1-app #pg-dash.dash-serio-v1 .dash-tab-panel--inicio:not([hidden]) {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
  body.manto-serio-v1-app #pg-dash.dash-serio-v1 .dash-tab-panel--inicio:not([hidden]) > .section,
  body.manto-serio-v1-app #pg-dash.dash-serio-v1 .dash-tab-panel--inicio:not([hidden]) .section-body,
  body.manto-serio-v1-app #pg-dash.dash-serio-v1 .dash-tab-panel--inicio:not([hidden]) .section-content {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   Partos — «Nacidos del año»: solo escritorio (≥768px).
   Centrado de título + tarjetas; en móvil se mantiene el layout base (index.html).
   Tarjetas KPI más legibles en PC (no usar tamaños compactos de móvil).
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 768px) {
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-serio-stats-wrap {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-serio-stats-head {
    justify-content: center !important;
    width: 100% !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-serio-stats-tit-wrap {
    flex: 0 1 auto !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: left !important;
    width: auto !important;
    max-width: 100% !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-serio-kpi-grid.partos-kpi-compact {
    display: grid !important;
    grid-template-columns: minmax(200px, 1fr) minmax(200px, 1fr) !important;
    max-width: 520px !important;
    width: 100% !important;
    margin-left: auto !important;
    margin-right: auto !important;
    gap: 12px !important;
    box-sizing: border-box !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-kpi-compact .sc.partos-kpi-h,
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-kpi-compact .sc.partos-kpi-m {
    padding: 12px 16px 14px !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-kpi-compact .partos-kpi-tit {
    font-size: 12px !important;
    margin-bottom: 6px !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-kpi-compact .partos-kpi-val {
    font-size: 32px !important;
  }
  body.manto-serio-v1-app #pg-nac.partos-serio-v1 .partos-kpi-compact .partos-kpi-sub {
    font-size: 11px !important;
    margin-top: 6px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   Sidebar izquierdo — SOLO escritorio (≥768px).
   Fijo sin scroll, ancho reducido, fondo slate (sin headerfon azul).
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 768px) {
  #app .nav-rail-scroll-ui {
    display: none !important;
  }

  html body #app .nav.nav--rail-cards,
  body.light html body #app .nav.nav--rail-cards,
  body:not(.light) html body #app .nav.nav--rail-cards {
    background:
      linear-gradient(
        180deg,
        rgba(255, 255, 255, 0.72) 0%,
        rgba(241, 245, 249, 0.88) 45%,
        rgba(226, 232, 240, 0.92) 100%
      ),
      url("icons/nav-sidebar-pc-bg.svg?v=20260518pcnav") center top / cover no-repeat !important;
    background-size: auto, cover !important;
    background-position: 0 0, center top !important;
    background-repeat: no-repeat, no-repeat !important;
    border-top: none !important;
    border-right: 1px solid var(--gris-300, #cbd5e1) !important;
    border-radius: 0 !important;
    box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.65) !important;
    -webkit-overflow-scrolling: auto !important;
    overscroll-behavior: none !important;
    touch-action: auto !important;
  }

  html body #app .nav.nav--rail-cards .nb,
  body.light html body #app .nav.nav--rail-cards .nb {
    background: transparent !important;
    border: none !important;
    border-left: 3px solid transparent !important;
    border-radius: 0 !important;
    color: var(--texto-base, #334155) !important;
    -webkit-text-fill-color: var(--texto-base, #334155) !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    text-shadow: none !important;
    min-height: 0 !important;
    transform: none !important;
    letter-spacing: 0.04em !important;
    line-height: 1.2 !important;
  }

  html body #app .nav.nav--rail-cards .nb:not(.active):hover {
    background: rgba(71, 85, 105, 0.08) !important;
    border: none !important;
    border-left: 3px solid transparent !important;
    color: var(--texto-fuerte, #0f172a) !important;
    -webkit-text-fill-color: var(--texto-fuerte, #0f172a) !important;
    box-shadow: none !important;
    transform: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    text-shadow: none !important;
  }

  html body #app .nav.nav--rail-cards .nb:not(.active):active {
    background: rgba(71, 85, 105, 0.12) !important;
    border-left: 3px solid transparent !important;
  }

  html body #app .nav.nav--rail-cards .nb.active,
  html body #app .nav.nav--rail-cards .nb.active:hover,
  html body #app .nav.nav--rail-cards .nb.active:active,
  html body #app .nav.nav--rail-cards .nb[aria-current='page'] {
    background: rgba(71, 85, 105, 0.14) !important;
    border: none !important;
    border-left: 3px solid #475569 !important;
    color: var(--texto-fuerte, #0f172a) !important;
    -webkit-text-fill-color: var(--texto-fuerte, #0f172a) !important;
    box-shadow: none !important;
    transform: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    text-shadow: none !important;
    font-weight: 800 !important;
  }

  html body #app .nav.nav--rail-cards .nb.active .ni,
  html body #app .nav.nav--rail-cards .nb.active .ni img.ni-img,
  html body #app .nav.nav--rail-cards .nb.active .ni-img {
    filter: none !important;
    opacity: 1 !important;
  }

  html body #app .nav.nav--rail-cards {
    --nav-ico: 20px;
    gap: 1px !important;
    padding: 6px 0 8px !important;
  }

  html body #app .nav.nav--rail-cards .nb {
    padding: 5px 8px !important;
    margin: 0 4px !important;
    min-height: 28px !important;
    gap: 8px !important;
    border-radius: 6px !important;
    font-size: 10.5px !important;
  }

  html body #app .nav.nav--rail-cards .nb .ni {
    min-height: 0 !important;
    width: 20px;
    flex: 0 0 20px;
    justify-content: center;
  }

  html body #app .nav.nav--rail-cards .nb .ni-img {
    width: 20px !important;
    height: 20px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════
   Contención horizontal — escritorio (monitores 24–27", 1080p/1440p).
   El grid #app sin minmax(0,1fr) + hijos max-content provocaban scroll en toda la página.
   ═══════════════════════════════════════════════════════════════ */
@media (min-width: 768px) {
  html,
  body {
    /* clip evita barra horizontal sin convertir overflow-y en auto (rueda del ratón) */
    overflow-x: clip;
    max-width: 100%;
  }

  #app > .pg,
  #app > .pg.active {
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: clip !important;
    overflow-y: visible !important;
  }

  #app > .pg > .section,
  #app > .pg > .section > .section-header,
  #app > .pg > .section > .section-body,
  #app > .pg > .section > .section-body > .section-content {
    min-width: 0 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  #pg-ani.animales-serio-v1 .ani-serio-panel,
  #pg-ani.animales-serio-v1 .ani-serio-hero-toolbar,
  #pg-ani.animales-serio-v1 .ani-serio-panel--filters {
    min-width: 0 !important;
    max-width: 100% !important;
  }
}

/* Padding lateral más compacto en anchos típicos 27" (≈1200–1600px útiles) */
@media (min-width: 768px) and (max-width: 1600px) {
  #app > .pg {
    padding: 18px 16px 24px !important;
  }
}

/* Toolbar hero: buscador + CTA en una columna si no caben en 5fr|3fr */
@media (min-width: 768px) and (max-width: 1320px) {
  #pg-ani.animales-serio-v1 .ani-serio-hero-toolbar .ani-topbar,
  #pg-ani.animales-serio-v1 .ani-serio-hero-toolbar .ani-serio-toolbar,
  #pg-nac.partos-serio-v1 .partos-serio-hero-toolbar .ani-topbar,
  #pg-nac.partos-serio-v1 .partos-serio-hero-toolbar .ani-serio-toolbar,
  #pg-pot.potreros-serio-v1 .pot-serio-hero-toolbar .ani-topbar,
  #pg-pot.potreros-serio-v1 .pot-serio-hero-toolbar .ani-serio-toolbar,
  #pg-ins.insumos-serio-v1 .ins-serio-hero-toolbar .ani-topbar,
  #pg-ins.insumos-serio-v1 .ins-serio-hero-toolbar .ani-serio-toolbar,
  #pg-cal.eventos-serio-v1 .cal-serio-hero-toolbar .ani-topbar,
  #pg-cal.eventos-serio-v1 .cal-serio-hero-toolbar .ani-serio-toolbar,
  #pg-carne.carne-serio-v1 .carne-serio-hero-toolbar .ani-topbar,
  #pg-carne.carne-serio-v1 .carne-serio-hero-toolbar .ani-serio-toolbar {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 8px !important;
  }

  #pg-ani.animales-serio-v1 .ani-add-btn,
  #pg-ani.animales-serio-v1 .ani-serio-hero-toolbar .btn.bg_ {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* Mosaico animales: menos columnas en escritorio estrecho (evita tarjetas que empujan el ancho) */
@media (min-width: 768px) and (max-width: 1099px) {
  #pg-ani .ani-gallery-mosaic,
  #pg-nac .nac-gallery-mosaic {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (min-width: 768px) and (max-width: 999px) {
  #pg-ani .ani-gallery-mosaic,
  #pg-nac .nac-gallery-mosaic {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
