/* =========================
   Tokens mínimos (colores/espacios)
   ========================= */
:root {
  --verde: #155e40;
  --verde-osc: #0f4a32;
  --crema: #f7f4ed;
  --texto: #1f1f1f;
  --maxw: 1240px;
  --gap: 16px;

  /* Layout con header + sidebar sticky */
  --header-h: 72px;
  /* actualizado por JS */
  --layout-gap-top: 6px;
  /* separación bajo header en desktop */
}

/* =========================
     Layout global (wrapper 2 columnas)
     ========================= */
#app.layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 24px;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 16px var(--gap);
  /*padding-top: calc(var(--header-h) + var(--layout-gap-top));*/ 
  min-height: auto;
}

/* Evitar colapso de márgenes en el contenido inyectado */
#contenido {
  min-height: auto;
}

#contenido>.page:first-child,
#contenido>section:first-child {
  margin-top: 0;
}

/* ===== MÓVIL: separación mínima bajo header ===== */
@media (max-width: 900px) {
  :root {
    --layout-gap-top: 0px;
  }

  #app.layout {
    grid-template-columns: 1fr;
    gap: 16px;
    /* ✅ Margen pequeño: 1em en lugar de compensar todo el header */
    padding-top: 1em;
    min-height: auto;
  }

  #contenido {
    min-height: 0;
    margin-top: 0;
    padding-top: 0;
  }
}

